首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >额外的反斜杠\当选择...到OUTFILE中...在MySQL中

额外的反斜杠\当选择...到OUTFILE中...在MySQL中
EN

Stack Overflow用户
提问于 2011-03-11 09:43:46
回答 5查看 16.6K关注 0票数 12

所以我尝试将一个MySQL表导出到CSV中。我使用这个查询:

代码语言:javascript
复制
SELECT * FROM business WHERE id > 0 AND id <= 20000 INTO OUTFILE "business.csv"
FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"'
LINES TERMINATED BY "\n";

输出结果如下所示:

http://postimage.org/image/2ghyenh5w/full/

这样做的问题是,在有换行符的地方总是有一个额外的反斜杠,比如在地址字段中。

但是,从phpMyAdmin导出的CSV没有:

http://postimage.org/image/2gi026tno/full/

有没有什么方法可以选择...输出文件..。做同样的事?

我正在处理的表有2000万条记录,对于每个导出操作,phpMyAdmin只能处理大约500,000条记录-否则它将变为空白,或者mysql服务器消失,等等。

EN

回答 5

Stack Overflow用户

发布于 2011-08-13 03:10:56

我也遇到了同样的问题,我发现(在将csv文件导入到电子表格中之后) MySQL表中的一些varchar字段中有换行。删除换行符后,导出工作正常。

票数 1
EN

Stack Overflow用户

发布于 2016-08-26 15:56:27

试试这个:

代码语言:javascript
复制
SELECT * FROM business WHERE id > 0 AND id <= 20000 INTO OUTFILE "business.csv"
FIELDS TERMINATED BY  ',' OPTIONALLY ENCLOSED BY '"' ESCAPED BY '\' 
LINES TERMINATED BY '\n';

我意识到使用escaped by '\' makes去掉了导出结果上的反斜杠。

票数 0
EN

Stack Overflow用户

发布于 2017-08-14 14:19:31

在这里得到了答案https://bugs.mysql.com/bug.php?id=46434

要点是:

INTO OUTFILE用于生成可通过load DATABy加载的结果。缺省转义方式为“\”若要禁用转义,请使用转义方式“”

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5268088

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档