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