MySQL導出數據的目的有不少種,如數據庫備份、表結構導出、表數據導出、分析數據採起等。html
先說最短小精悍的select into outfile, 這是小型數據庫分析數據最經常使用的採集數據方式,具體語法以下:
【select 語句】 into outfile 【導出文件名】 【導出參數】mysql
【select語句】是經典的查詢SQL,能夠指定列、能夠有where條件、group、order、limit等。
【導出文件名】是目標文件的完整路徑。因爲mysql帳戶的權限問題,一般咱們會將文件導出到臨時目錄,如/tmp/mysql/user/201810.csv
【導出參數】sql
譬如:數據庫
select * from platform_user into outfile '/tmp/mysql/user/201810.csv' fields terminated by ',' enclosed by '"' lines starting by '\r' terminated by '\n';
若是導出的數據,涉及到中文,打開csv可能會看到亂碼。處理亂碼,首先要確保數據庫支持中文(一般設置UTF8編碼便可)
vim /etc/my.cnf, 添加以下幾個選項:vim
[client] default-character-set=utf8 [mysqld] character_set_server=utf8 [mysql] default-character-set=utf8
即使數據庫已是utf8,導出的文件download本地依然可能有亂碼,在服務器上less,tail看到的結果都是正常的?
在本地環境(windows)用記事本打開csv,另存編碼格式ANSI便可,這是因爲excel的編碼格式決定的。windows
做爲開發人員或者運維人員,mysqldump使用的頻率更高,由於它能作的事情更多。mysqldump屬於邏輯備份工具,由於它導出的是結果,多以SQL的形式展現,並不記錄數據的變化過程。關於物理備份,能夠參照一本名爲「MySQL技術內幕」的書籍,其中有詳細的描述。
mysqldump的語法很簡單,即mysqldump 【options】> dump.sql
api
可是options的可選參數卻不少,手冊上將他分了幾大類,連接option、文件option、數據定義DDL option、Debug option、國際化option、集羣Replication option、格式 option、性能option、事務option等。感興趣的同窗能夠參照MYSQL官方手冊的定義,這裏僅介紹幾種常見的應用場景。服務器
導出表結構和最新的數據
mysqldump -uroot -p platform88 > /data/mysql/dump20181020.sql, 再輸入密碼便可。架構
--routines, -R 導出存儲過程及函數
mysqldump -uroot -p -R platform88 > /data/mysql/dump20181022.sqlless
若是想跳過多個表,屢次使用該選項 :
mysqldump -uroot -p -R --ignore-table=platform88.platformapitrace --ignore-table=platform88.platformaccount platform88 > /data/mysql/dump20181022.sql
注意,該選項值必須包含schema。
使用lock tables時,須要指定數據庫,即-B參數。
6. --no-create-info -t 僅導出數據,不建立表結構
mysqldump -uroot -p -R -t -B platform88 > /data/mysql/dump20181022.sql
-opt 選項套餐
-opt默認會執行以下選項:
--add-drop-table --add-locks --create-options --disable-keys --extended-insert --lock-tables --quick --set-charset的縮寫。
9. --compact 壓縮--compact默認開啓以下選項: --skip-add-drop-table, --skip-add-locks, --skip-comments, --skip-disable-keys, and --skip-set-charset options.