MySQL导出数据的目的有不少种,如数据库备份、表结构导出、表数据导出、分析数据采起等。html
先说最短小精悍的select into outfile, 这是小型数据库分析数据最经常使用的采集数据方式,具体语法以下:
【select 语句】 into outfile 【导出文件名】 【导出参数】mysql
【select语句】是经典的查询SQL,能够指定列、能够有where条件、group、order、limit等。
【导出文件名】是目标文件的完整路径。因为mysql帐户的权限问题,一般咱们会将文件导出到临时目录,如/tmp/mysql/user/201810.csv
【导出参数】sql
譬如:数据库
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, 添加以下几个选项:vim
[client] default-character-set=utf8 [mysqld] character_set_server=utf8 [mysql] default-character-set=utf8
即使数据库已是utf8,导出的文件download本地依然可能有乱码,在服务器上less,tail看到的结果都是正常的?
在本地环境(windows)用记事本打开csv,另存编码格式ANSI便可,这是因为excel的编码格式决定的。windows
做为开发人员或者运维人员,mysqldump使用的频率更高,由于它能作的事情更多。mysqldump属于逻辑备份工具,由于它导出的是结果,多以SQL的形式展现,并不记录数据的变化过程。关于物理备份,能够参照一本名为“MySQL技术内幕”的书籍,其中有详细的描述。
mysqldump的语法很简单,即mysqldump 【options】> dump.sql
api
可是options的可选参数却不少,手册上将他分了几大类,连接option、文件option、数据定义DDL option、Debug option、国际化option、集群Replication option、格式 option、性能option、事务option等。感兴趣的同窗能够参照MYSQL官方手册的定义,这里仅介绍几种常见的应用场景。服务器
导出表结构和最新的数据
mysqldump -uroot -p platform88 > /data/mysql/dump20181020.sql, 再输入密码便可。架构
--routines, -R 导出存储过程及函数
mysqldump -uroot -p -R platform88 > /data/mysql/dump20181022.sqlless
若是想跳过多个表,屡次使用该选项 :
mysqldump -uroot -p -R --ignore-table=platform88.platformapitrace --ignore-table=platform88.platformaccount platform88 > /data/mysql/dump20181022.sql
注意,该选项值必须包含schema。
使用lock tables时,须要指定数据库,即-B参数。
6. --no-create-info -t 仅导出数据,不建立表结构
mysqldump -uroot -p -R -t -B platform88 > /data/mysql/dump20181022.sql
-opt 选项套餐
-opt默认会执行以下选项:
--add-drop-table --add-locks --create-options --disable-keys --extended-insert --lock-tables --quick --set-charset的缩写。
9. --compact 压缩--compact默认开启以下选项: --skip-add-drop-table, --skip-add-locks, --skip-comments, --skip-disable-keys, and --skip-set-charset options.