使用mysqldump把mysql數據庫的數據導出到文件中還是挺方便的;
比如說要導出baijunyao數據庫;
// mysqldump -u用戶名 -p 數據庫名 [表名]> 導出的文件名 mysqldump -uroot -p baijunyao > baijunyao.sql
導出baijunyao數據庫中的users表;
mysqldump -uroot -p baijunyao users > baijunyao.sql
但是有時候當表的數據比較多的時候;
整張表都導出的話就比較坑爹了;
我只是想要兩列的內容;
而你卻給了我整個世界;
這時候就需要一個導出指定字段的方法了;
比如說導出users表的id和name字段;
mysql -uroot -p baijunyao -e "SELECT id,name from users INTO OUTFILE'/tmp/bjy_users.sql'"
然而;如果人品不好的話;
可能看到的是如下錯誤;
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%';
主要是看 secure_file_priv ;
意思就是必須導出到 secure_file_priv 指定的目錄下;
mysql -uroot -p baijunyao -e "SELECT id,name from users INTO OUTFILE'/var/lib/mysql-files/baijunyao.sql'"
罷特;如果趕上本命年還沒穿紅;
secure_file_priv 的 value 為 NULL;
則代表不允許導出;
好吧;這人品;也就告別自行車了;
別放棄治療;咱找到mysql的配置項文件my.cnf;
在 [mysqld] 下面添加;
[mysqld] secure_file_priv = 指定目錄
最后再來個彩蛋;
咱還可以再進一步;
在限制指定字段的情況下;
還可以用where限制條數;
撒氣矮子;
mysql -uroot -p baijunyao -e "SELECT id,name from users where id>10 INTO OUTFILE'/var/lib/mysql-files/baijunyao.sql'"