mysql 导出csv 遇到些问题整理包括一些参数说明
2014-04-23 17:18
387 查看
sql导出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被转义,以便更容易地使用调页程序观看。
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 主主同步遇到的问题,及一些参数说明
- wordpress迁移以及遇到的一些问题[mysql备份导入导出][固定链接404]
- wordpress迁移以及遇到的一些问题[mysql备份导入导出][固定链接404]
- 近期网友遇到的一些问题,整理出来 大家可以学习 交流 MySQL问题及解答
- Mysql 启动时遇到的一些问题及解决办法
- MAC下遇到的一些问题整理
- mysql 关于查询时间的中工作中遇到的一些问题 有代表性的
- 安装mysql时遇到的一些问题总结 一
- MySQL InnoDB的一些参数说明
- 整理PHP_YII环境安装遇到的一些问题
- Java连接mysql中遇到的一些问题及解决方法
- Python点滴(八)—图片序列化转为csv格式中遇到的一些问题
- Genymotion安装说明及遇到一些问题的解决办法
- MySQL windows下安装一些遇到的的问题
- 远程访问MySQL遇到的一些问题
- 记录一下Mysql中数据导入导出遇到的问题
- 详述 MySQL 导出数据遇到 secure-file-priv 的问题
- 【shell mysql 导出数据到csv脚本,完美解决乱码转义符等问题】-费元星
- 使用mysql-5.7.17-winx64遇到的一些问题
- MySql 5.6 遇到的一些问题