mysql導出指定字段或指定數據到文件中


使用mysqldump把mysql數據庫的數據導出到文件中還是挺方便的;
比如說要導出baijunyao數據庫;

// mysqldump -u用戶名 -p 數據庫名 [表名]> 導出的文件名 mysqldump -uroot -p baijunyao > baijunyao.sql
Bash

導出baijunyao數據庫中的users表;

mysqldump -uroot -p baijunyao users > baijunyao.sql
Bash

但是有時候當表的數據比較多的時候;
整張表都導出的話就比較坑爹了;
我只是想要兩列的內容;
而你卻給了我整個世界;
這時候就需要一個導出指定字段的方法了;
比如說導出users表的id和name字段;

mysql -uroot -p baijunyao -e "SELECT id,name from users INTO OUTFILE'/tmp/bjy_users.sql'"
Bash

然而;如果人品不好的話;
可能看到的是如下錯誤;

ERROR 1290 (HY000) at line 1: The MySQL server is running with the --secure-file-priv option so it cannot execute this statement
請容許我做一個悲傷的表情;
這個時候;登錄mysql;
執行如下命令;

show variables like '%secure%';
Bash


主要是看 secure_file_priv ;
意思就是必須導出到 secure_file_priv 指定的目錄下;

mysql -uroot -p baijunyao -e "SELECT id,name from users INTO OUTFILE'/var/lib/mysql-files/baijunyao.sql'"
Bash

罷特;如果趕上本命年還沒穿紅;
secure_file_priv 的 value 為 NULL;
則代表不允許導出;
好吧;這人品;也就告別自行車了;
別放棄治療;咱找到mysql的配置項文件my.cnf;
在 [mysqld] 下面添加;

[mysqld] secure_file_priv = 指定目錄
Bash

最后再來個彩蛋;
咱還可以再進一步;
在限制指定字段的情況下;
還可以用where限制條數;
撒氣矮子;

mysql -uroot -p baijunyao -e "SELECT id,name from users where id>10 INTO OUTFILE'/var/lib/mysql-files/baijunyao.sql'"
Bash

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM