-- 使用 mysql 帶-e選項來完成
成都創(chuàng)新互聯(lián)公司專注為客戶提供全方位的互聯(lián)網綜合服務,包含不限于網站設計、網站建設、平山網絡推廣、微信平臺小程序開發(fā)、平山網絡營銷、平山企業(yè)策劃、平山品牌公關、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運營等,從售前售中售后,我們都將竭誠為您服務,您的肯定,是我們最大的嘉獎;成都創(chuàng)新互聯(lián)公司為所有大學生創(chuàng)業(yè)者提供平山建站搭建服務,24小時服務熱線:18982081108,官方網址:sd-ha.com
mysql -uusername -ppassword -e "source e:/a.sql " e:/a.log
0 sql文件一般是創(chuàng)建表、視圖的ddl語句。
可在mysql命令終端、mysql圖形化工具(如heidisql, navicat工具等)的查詢窗口執(zhí)行。
執(zhí)行語句:source d:/easuduo.sql; --最好使用絕對路徑
1 執(zhí)行注意事項:
要先創(chuàng)建相關的數據庫;
可能需要先定位到相關數據庫下;
從上邊語句 CREATE TABLE IF NOT EXISTS `easyduo`.`category` 看出,需先創(chuàng)建名為easyduo的數據庫(create database easyduo;),再定位到其下(use easyduo;),然后執(zhí)行該sql文件即可。
查找mysql安裝在哪個目錄
#whereis mysql
然后把mysql的bin目錄添加到$PATH環(huán)境變量,或把mysql的bin目錄的文件都鏈接到/usr/bin中。
大多情況下,需要可靠而有效地克隆 MySQL 實例數據。這包括 MySQL 高可用的解決方案,其中需要在將實例加入組復制集群之前配置實例,或者在經典復制模型中將其添加為 Slave。
為復制拓撲而創(chuàng)建 MySQL 副本一直很麻煩。涉及的步驟很多,首先要備份 MySQL 服務器,通過網絡將備份傳輸到我們想要添加到復制集的新 MySQL 節(jié)點,然后在該節(jié)點上恢復備份并手動啟動 MySQL 服務器。為了高可用,最好還要將其正確設置備份的 GTID,并啟動并運行群集。涉及的手動步驟數量過多不利于高可用。CLONE 插件解決了這個問題并簡化了副本配置。使您可以使用 MySQL 客戶端(和 SQL 命令)來配置新節(jié)點并在發(fā)生時觀察克隆進度。無需手動處理多個步驟并維護自己的基礎架構來配置新的 MySQL 節(jié)點。
MySQL 8.0.17 引入了 CLONE SQL 語句,使當前的 MySQL 服務器成為另一個運行在不同節(jié)點的 MySQL 服務器的“克隆”。我們將執(zhí)行 clone 語句的服務器實例稱為“受體”??寺〉脑捶掌鲗嵗Q為“供體”。供體克隆以一致的快照存儲在 InnoDB 存儲引擎中的所有數據和元數據,以替換受體中的數據。
成功執(zhí)行 CLONE SQL 語句后,將自動重新啟動受體服務器。重新啟動涉及恢復克隆的快照數據,就像用老方法復制數據一樣?;謴屯瓿珊?,受體就是供體的克隆版,隨時可以使用!
這里有一些關于克隆過程的重要注意事項。
不克隆 MySQL 配置參數,并且受體保留所有原始配置參數,如克隆之前。這樣做是因為許多配置可能特定于節(jié)點(例如 PORT),因此保留它們似乎是一個不錯的選擇。另一方面,一些存儲配置確實需要在供體和受體之間匹配(例如 innodbpagesize),如果這樣的配置參數不匹配,CLONE 將報告錯誤。
CLONE?插件不會克隆二進制日志。
CLONE?插件目前僅支持 InnoDB 存儲引擎。在其他存儲引擎(如 MyISAM 和 CSV)中創(chuàng)建的表將被克隆為空表??寺』A架構的設計允許克隆 MySQL 支持的任何存儲引擎。但是,只有 InnoDB 序列化和反序列化方法已經實現并經過測試。
克隆會阻止供體中的所有并發(fā) DDL。
需要注意的事實是受體放棄所有數據以及任何二進制日志,以便成為供體實例的克隆。在執(zhí)行 CLONE 之前,如果認為有必要,需要備份當前受體數據。
你所說的可執(zhí)行文件,就是jar包嗎?
自己生成的jar文件,執(zhí)行需要指明所依賴的其他lib包,建議查下,如何配置。應該是你的程序的運行時沒有指定依賴包。
大家都知道一個java應用項目可以打包成一個jar,當然你必須指定一個擁有main函數的main?class作為你這個jar包的程序入口。
具體的方法是修改jar包內目錄META-INF下的MANIFEST.MF文件。
比如有個叫做test.jar的jar包,里面有一個擁有main函數的main?class:test.someClassName
我們就只要在MANIFEST.MF里面添加如下一句話:
Main-Class:?test.someClassName
然后我們可以在控制臺里輸入java?-jar?test.jar即可以運行這個jar。
但是我們這個項目需要引用其他第三方的jar包,在eclipse里面以項目jar包的形式引用了這個叫做some.jar的包,當時放在項目的lib子目錄下,最后項目打包時把這個some.jar也打進來了,但是用java?-jar執(zhí)行這個test.jar的時候報找不到Class異常,原因就是jar引用不到放在自己內部的jar包。
那怎么辦?
運行時將其加入classpath的方式行不行?就是在運行jar的同時加入classpath參數:
java?-classpath?some.jar?-jar?test.jar
這種方式是不行的,因為使用classpath指定的jar是由AppClassloader來加載,java?命令?加了-jar?參數以后,AppClassloader就只關注test.jar范圍內的class了,classpath參數失效。
那該怎么引用其他的jar包呢?
方法一、使用Bootstrap?Classloader來加載這些類
我們可以在運行時使用如下參數:
-Xbootclasspath:完全取代系統(tǒng)Java?classpath.最好不用。
-Xbootclasspath/a:?在系統(tǒng)class加載后加載。一般用這個。
-Xbootclasspath/p:?在系統(tǒng)class加載前加載,注意使用,和系統(tǒng)類沖突就不好了.
win32?java?-Xbootclasspath/a:?some.jar;some2.jar;?-jar?test.jar
unix????java?-Xbootclasspath/a:?some.jar:some2.jar:?-jar?test.jar
win32系統(tǒng)每個jar用分號隔開,unix系統(tǒng)下用冒號隔開
方法二、使用Extension?Classloader來加載
你可以把需要加載的jar都扔到%JRE_HOME%/lib/ext下面,這個目錄下的jar包會在Bootstrap?Classloader工作完后由Extension?Classloader來加載。非常方便,非常省心。:)
方法三、還是用AppClassloader來加載,不過不需要classpath參數了
我們在MANIFEST.MF中添加如下代碼:
Class-Path:?lib/some.jar
lib是和test.jar同目錄的一個子目錄,test.jar要引用的some.jar包就在這里面。
然后測試運行,一切正常!
如果有多個jar包需要引用的情況:
Class-Path:?lib/some.jar?lib/some2.jar
每個單獨的jar用空格隔開就可以了。注意使用相對路徑。
另:如果META-INF?下包含INDEX.LIST文件的話,可能會使Class-Path配置失效。INDEX.LIST是Jar打包工具打包時生成的索引文件,刪除對運行不產生影響。
方法四、自定義Classloader來加載
這種方法是終極解決方案,基本上那些知名java應用都是那么干的,如tomcat、jboss等等。
這種方式有點復雜,需要專門開貼討論。關于ClassLoader的原理和自定義ClassLoader可以參考這篇
總結:
以上四種方法都可以用,特別是程序運行在非常單純的環(huán)境中時。但是,如果是運行在多任務,多應用的環(huán)境中時,最好每個應用都能相互獨立,第一種和第二種方案都有可能對其他應用產生影響,因此最好就是選擇第三種和第四種。
服務器的話可以使用計劃任務。
如果是虛擬主機只能使用死循環(huán)+判定條件了。
網站標題:mysql怎么生成可執(zhí)行,mysql如何執(zhí)行
轉載注明:http://sd-ha.com/article46/hseseg.html
成都網站建設公司_創(chuàng)新互聯(lián),為您提供移動網站建設、外貿網站建設、服務器托管、小程序開發(fā)、建站公司、虛擬主機
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)