您的位置:首页 > 数据库 > MySQL

mysql 导出csv 遇到些问题整理包括一些参数说明

2014-04-23 17:18 387 查看
sql导出csv 文件语句如下:

select a.positionId,c.serverId,c.name from position_info a, hero_base_info  b, hero_info c where a.officalId=b.heroId and b.heroId=c.id into outfile'/tmp/db.csv' fields terminated by ',' optionally enclosed by '"' escaped by '"' lines terminated by '\r\n';


into outfile'/tmp/db.csv' fields terminated by ',' optionally enclosed by '"' escaped by '"' lines terminated by '\r\n';
FIELDS TERMINATED BY ',' 字段间分割符
OPTIONALLY ENCLOSED BY '"' 将字段包围 对数值型无效
LINES TERMINATED BY '\n' 换行符
因为office默认的是gb2312编码,服务器端生成的很有可能是utf-8编码,可以在服务器端使用iconv来进行编码转换:
iconv -futf8 -tgb2312 -oresults.csv tmp.csv
或者可以使用

enca  -L zh_CN  -x gb2312  *.csv


SELECT...INTO OUTFILE 'file_name'形式的SELECT可以把被选择的行写入一个文件中。该文件被创建到服务器主机上,因此您必须拥有FILE权限,才能使用此语法。file_name不能是一个原有的文件。原有文件会阻止例如“/etc/passwd”的文件和数据库表被销毁。
SELECT...INTO OUTFILE语句的主要作用是让您可以非常快速地把一个表转储到服务器机器上。如果您想要在服务器主机之外的部分客户主机上创建结果文件,您不能使用SELECT...INTO OUTFILE。在这种情况下,您应该在客户主机上使用比如“mysql –e "SELECT ..." > file_name”的命令,来生成文件。
SELECT...INTO OUTFILE是LOAD DATA INFILE的补语;用于语句的exort_options部分的语法包括部分FIELDS和LINES子句,这些子句与LOAD DATA INFILE语句同时使用。请参见13.2.5节,“LOAD DATA INFILE语法”
FIELDS ESCAPED BY用于控制如何写入特殊字符。如果FIELDS ESCAPED BY字符不是空字符,则被用于在输出中对以下字符设前缀:
oFIELDS ESCAPED BY字符
oFIELDS [OPTIONALLY] ENCLOSED BY字符
oFIELDS TERMINATED BY和LINES TERMINATED BY值的第一个字符
oASCII 0(在编写时接在转义符后面的是ASCII ‘0’,而不是一个零值字节)
如果FIELDS ESCAPED BY字符是空字符,则没有字符被转义,并且NULL被作为NULL输出,而不是作为\N输出。指定一个空的转义符不是一个好的主意。特别是当您的数据中的字段值包含刚被给予的清单中的字符时,更是如此。
其原因是您必须对所有FIELDS TERMINATED BY, ENCLOSED BY, ESCAPED BY或LINES TERMINATED BY字符进行转义,才能可靠地读取文件并返回。ASCII NUL被转义,以便更容易地使用调页程序观看。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  mysql where 换行符