在日常工作中经常会遇见导出表中的数据到csv文件的操作,这里就简单总结一下导出的操作。
下面对csv文件的描述是摘录:
据RFC4180文档设置的,该文档全称Common Format and MIME Type for Comma-Separated Values (CSV) Files,其中详细描述了CSV格式,其要点包括: (1)字段之间以逗号分隔,数据行之间以\r\n分隔; (2)字符串以半角双引号包围,字符串本身的双引号用两个双引号表示。
这里关键点,我们导出的数据文件字段之间应该以逗号分隔,数据行之间应该以\r\n分隔;字段的值之间以半角双引号包围,字段值中的双引号以两个双引号表示。
导出表数据的三种方法:
使用select .... into outfile的方法
直接在mysql的交互界面使用select命令导出数据到文件。
root@newsdb 09:53:08>select * from t_hk_stock_news where news_time > "2018.12.31 23:59:59" into outfile "/db/test.csv"; ERROR 1290 (HY000): The MySQL server is running with the --secure-file-priv option so it cannot execute this statement
以上报错需要在配置文件中指定secure_file_priv参数的值,这个值指向一个地址,导出的文件需要写入到对应的地址中。
在不知道你个默认的情况下,导出文件中字段之间用TAB键隔开,每行记录之间用\n换行符隔开,
root@newsdb 01:44:05>select * from t_hk_stock_news limit 1 into outfile "/db/test1.csv"; Query OK, 1 row affected (0.00 sec) root@newsdb 01:44:10> [root@test2 db]# head -n2 test1.csv 000028952-c807-11e7-85f5-00163e12520202