MySQL 導出數(shù)據(jù)為csv格式的方法
方案有很多種,我這里簡單說一下:
1. into outfile
SELECT * FROM mytable
INTO OUTFILE '/tmp/mytable.csv'
FIELDS TERMINATED BY ','
OPTIONALLY ENCLOSED BY '"'
LINES TERMINATED BY '\n';
在我使用過程中發(fā)現(xiàn)一個特別嚴重問題,這里面不能插入查詢條件,比如where這些,也就是說只能整表導出,不知道是不是我的寫法有問題,有知道朋友請給我留言。
第二個問題是,outfile的路徑一定要有寫權(quán)限,我們mysql的進程權(quán)限一般是mysql用戶,因此最好導出到/tmp目錄下面。
2. 通過結(jié)合sed
mysql -uroot test -e "select ip from server where a.name like '%abc%'" -N -s | sed -e 's/^/"/g;s/$/"\n/g'; > /tmp/test.csv
這里首先使用mysql命令的-e參數(shù)來執(zhí)行sql語句,然后通過-N來去掉輸出結(jié)果中列名,-s去掉輸出結(jié)果中的各種劃線。
然后使用sed命令輸出結(jié)果中所有相關(guān)數(shù)據(jù)進行替換,其中替換了三處,1.在行首增加“,在行尾增加”和換行,在每個字段之間增加”,”來分隔。
3. 通過mysqldump來實現(xiàn)
mysqldump -u username -p -t -T/path/to/directory dbname table_name --fields-terminated-by=','
和1的方案差不多吧。
就當是一個筆記吧
- MySQL數(shù)據(jù)庫導入導出數(shù)據(jù)之報錯解答實例講解
- mysql實現(xiàn)從導出數(shù)據(jù)的sql文件中只導入指定的一個表
- 詳解Mysql導出數(shù)據(jù)的幾種方式
- MySQL導出數(shù)據(jù)遇到secure-file-priv問題的解決方法
- MySQL數(shù)據(jù)庫使用mysqldump導出數(shù)據(jù)詳解
- mysqldump命令導入導出數(shù)據(jù)庫方法與實例匯總
- MYSQL命令行導入導出數(shù)據(jù)庫詳解
- mysql 導入導出數(shù)據(jù)庫、數(shù)據(jù)表的方法
- 淺析Mysql 中如何導出數(shù)據(jù)
相關(guān)文章
MySql數(shù)據(jù)庫基礎(chǔ)知識點總結(jié)
這篇文章主要介紹了MySql數(shù)據(jù)庫基礎(chǔ)知識點,總結(jié)整理了mysql數(shù)據(jù)庫基本創(chuàng)建、查看、選擇、刪除以及數(shù)據(jù)類型相關(guān)操作技巧,需要的朋友可以參考下2020-06-06
idea 設(shè)置MySql主鍵的實現(xiàn)步驟
在IDE開發(fā)工具中也是可以使用mysql的,本文主要介紹了idea 設(shè)置MySql主鍵的實現(xiàn)步驟,文中通過圖文的非常詳細,需要的朋友們下面隨著小編來一起學習學習吧2024-03-03
mysql中find_in_set()函數(shù)的使用詳解
這篇文章主要介紹了mysql中find_in_set()函數(shù)的使用,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-05-05

