Mysql导出数据的几种方式

MySQL导出数据的目的有很多种,如数据库备份、表结构导出、表数据导出、分析数据采取等。

Part1 select into outfile

先说最短小精悍的select into outfile, 这是小型数据库分析数据最常用的采集数据方式,具体语法如下:
【select 语句】 into outfile 【导出文件名】 【导出参数】

【select语句】是经典的查询SQL,可以指定列、可以有where条件、group、order、limit等。
【导出文件名】是目标文件的完整路径。由于mysql账户的权限问题,通常我们会将文件导出到临时目录,如/tmp/mysql/user/201810.csv
【导出参数】

  • fields terminated by 'str':设置字段之间的分隔符,默认值是"\t"。
  • fields enclosed by 'char':设置包括住字段的值的符号,如单引号、双引号等,默认情况下不使用任何符号。
  • fields optionally enclosed by 'char':设置括住CHAR、VARCHAR和TEXT等字符型字段的分隔符,默认情况下不使用任何符号。
  • fields escaped by 'char':设置转义字符,默认值为"\"。
  • lines starting by 'str':设置每行数据开头的字符,可以为单个或多个字符。默认情况下不使用任何字符。
  • lines terminated by 'char':设置每行数据结尾的字符,可以为单个或多个字符。默认值是"\n"。

譬如:


select * from platform_user into outfile '/tmp/mysql/user/201810.csv' 
fields terminated by ',' 
          enclosed by '"'
lines starting by '\r'
         terminated by '\n';

如果导出的数据,涉及到中文,打开csv可能会看到乱码。处理乱码,首先要确保数据库支持中文(通常设置UTF8编码即可)
vim /etc/my.cnf, 添加如下几个选项:

[client]
default-character-set=utf8
[mysqld]
character_set_server=utf8
[mysql]
default-character-set=utf8

即便数据库已经是utf8,导出的文件download本地依然可能有乱码,在服务器上less,tail看到的结果都是正常的?
在本地环境(windows)用记事本打开csv,另存编码格式ANSI即可,这是由于excel的编码格式决定的。

Part2 mysqldump导出数据

猜你喜欢

转载自blog.51cto.com/10705830/2307299
今日推荐