MySQL学习随笔记录
安装选custmer自定义安装。默认安装全部在c盘。
自定义安装的时候有个advance port选项用来选择安装目录。
-----------------------mysql常见的一些操作命令--------------------------------
#切换当前目录到d盘下
d:
#切换到指定的目录下
cd d:\program files (x86)\mysql\mysql server 5.6\bin
#以root身份登录到mysql数据库,要控制命令在mysql服务目录下,在
mysql -u root -p -- 回车后会要求输入密码。
#显示mysql数据库包含的所有的数据库。
show databases;
#查看指定部分的数据库
show databases like “%sch%”;
/*
list of all mysql commands:
note that all text commands must be first on line and end with ';'
? (\?) synonym for `help'.
clear (\c) clear the current input statement.
connect (\r) reconnect to the server. optional arguments are db and host.
delimiter (\d) set statement delimiter.
ego (\g) send command to mysql server, display result vertically.
exit (\q) exit mysql. same as quit.
go (\g) send command to mysql server.
help (\h) display this help.
notee (\t) don't write into outfile.
print (\p) print current command.
prompt (\r) change your mysql prompt.
quit (\q) quit mysql.
rehash (\#) rebuild completion hash.
source (\.) execute an sql script file. takes a file name as an argument.
status (\s) get status information from the server.
tee (\t) set outfile [to_outfile]. append everything into given outfile.
use (\u) use another database. takes database name as argument.
charset (\c) switch to another charset. might be needed for processing binlog with multi-byte charsets.
warnings (\w) show warnings after every statement.
nowarning (\w) don't show warnings after every statement.
*/
#清屏。
cls --需退出mysql登录才行。属dos命令。不是mysql内部命令。
#密码修改:
#密码修改一,修改完成后要重启才能生效。在cmd窗口中执行。而不是mysql中。
mysqladmin -uroot -p password hqhq --特别注意password关键字后面要有一个空格,然后再跟新的密码。新密码无需用''括起来,也不要加;,否则这些也会是密码的一部分。
#密码修改二,修改完成后要重启才能生效。前提用管理员权限账号已经登录了mysql。
update mysql.user set password=password('hqhq') where user='root'; --特别注意password中''括起来的是新密码。
-------------------------------------------------库操作--------------------------------------------------------------
#查看mysql默认的字符集编码格式
show variables like '%char%';
+--------------------------+---------------------------------------------------------------+
| variable_name | value |
+--------------------------+---------------------------------------------------------------+
| character_set_client | gbk |
| character_set_connection | gbk |
| character_set_database | utf8 |
| character_set_filesystem | binary |
| character_set_results | gbk |
| character_set_server | utf8 |
| character_set_system | utf8 |
| character_sets_dir | d:\program files (x86)\mysql\mysql server 5.6\share\charsets\ |
+--------------------------+---------------------------------------------------------------+
/*设置字符集格式
以下操作只是临时的,也就是对当前的会话有效,如果以后不想再修改,就加上关键字 global
比如 set global character_set_client=utf8;
执行命令:
set character_set_client=utf8;
set character_set_connection=utf8;
set character_set_database=utf8;
set character_set_results=utf8;
set character_set_filesystem=utf8;
*/
------------ 建库
create database hq;
--查看数据库所支持的校对集:
show collation;
--查看数据库的创建 sql 语句
show create database hq;
更新数据库
***数据库的名称是不可更改的选项。 如果要更新数据库名,一般做法是新建新库,然后
复制库的表和数据(后面再讲怎么操作)。
更新数据库字符集
alter databse c3gen charset gbk;
查看 数据库字符集
show variables like 'character_set_%';
-- -- 删除数据库
drop database hq;
--指定数据库使用
use hq;
--------------------------------数据库表操作-----------------------------------------------
--建表,建表之前需指定数据库
create table if not exists student(
-> student_id int primary key,
-> student_name varchar(25),
-> stu_age int(2),
-> stu_score int(2));
-------------------------------------------------------------
create table test(
-> id int,
-> name varchar(30))
-> charset utf8;
/*带上字符集是个好习惯。后面的例子我基本上都会带上。
if not exists: 如果表名不存在,那么就创建,否则不执行创建代码: 检查功能。
创建之前记得指定数据库,不然会报错。no database selected;
当然也可以这样创建 数据库名.表名。*/
--建表之前不指定数据库,建表语句中指定数据库
create table if not exists hq.student(
-> id int,
-> name varchar(30))
-> charset utf8;
--查看当前数据库下所有表
show tables;
--查看创建当前表的 sql 语句
show create table student;
create table `student` (
`student_id` int(11) not null,
`student_name` varchar(25) default null,
`stu_age` int(2) default null,
`stu_score` int(2) default null,
primary key (`student_id`)
) engine=innodb default charset=utf8 |
查看表结构
show columns from 表名;
desc/describe 表名。
--更新表名
rename table 表名 to 新表名;
表的字符集 alter table 表名 charset = 字符集;
更新表字段 可以灵活的使用 after,first 等关键字。
更新字段 modify 修改字段属性(数据类型等) change 修改字段名
--修改列的类型
alter table hqhq
-> modify name int;
-------改名---------------
alter table hqhq
-> change name age int;
------------列之后----------------
alter table hqhq
-> add column name varchar(30) after age;
--------首列---------
alter table hqhq
-> add column idcard varchar(30) first;
-------------删除字段 drop 字段名; ***在数据库中的所有删除 drop 操作均不可逆。
alter table hqhq
-> drop name;
--删除表比较简单,
drop table 表名……. 可以指定多张表。***在数据库中的所有删除
操作均不可逆。
-- ----------------------------------------------------------------
怎样从文本文件执行sql语句
mysql客户程序一般交互使用:
shell> mysql db_name
还可以将sql语句放到一个文件中然后告诉mysql从该文件读取输入。要想实现,创建一个文本文
件text_file,并包含你想要执行的语句。然后按如下所示调用mysql:
shell> mysql db_name< text_file
还可以用一个use db_name语句启动文本文件。在这种情况下,不需要在命令行中指定数据库名:
shell> mysql < text_file
如果正运行mysql,可以使用source或\.命令执行sql脚本文件:
mysql> source filename
mysql> \. filename
有时想要使用脚本来向用户显示进度信息;为此可以插入下述行:
select '<info_to_display>' as ' ';
将输出<info_to_display>。
-- ------------------------------在批处理模式下使用mysql--------------------------------------
为了做到这些,把你想要运行的命令放在一个文件中,然后告诉mysql从文件读取它的输入:
shell> mysql < batch-file
如果在windows下运行mysql,并且文件中有一些可以造成问题的特殊字符,可以这样操作:
c:\> mysql -e "source batch-file"
如果你需要在命令行上指定连接参数,命令应为:
shell> mysql -h host-u user-p < batch-file
enter password: ********
当这样操作mysql时,则创建一个脚本文件,然后执行脚本。
如果你想在语句出现错误的时候仍想继续执行脚本,则应使用--force命令行选项。
为什么要使用一个脚本?有很多原因:
● 如果你需要重复运行查询(比如说,每天或每周),可以把它编成一个脚本,则每次执行时
不必重新键入。
● 可以通过拷贝并编辑脚本文件从类似的现有的查询生成一个新查询。
● 当你正在开发查询时,批模式也是很有用的,特别对多行命令或多语句命令序列。如果你
犯了一个错误,你不必重新输入所有内容,只需要编辑脚本来改正错误,然后告诉mysql再
次执行脚本。
● 如果你有一个产生多个输出的查询,你可以通过一个分页器而不是盯着它翻屏到屏幕的顶
端来运行输出:
• shell> mysql < batch-file | more
● 你可以捕捉文件中的输出以便进行进一步的处理:
• shell> mysql < batch-file > mysql.out
● 你可以将脚本分发给另外的人,以便他们也能运行命令。
● 某些情况不允许交互地使用,例如, 当你从一个cron任务中运行查询时。在这种情况下,你
必须使用批模式。
当你以批模式运行mysql时,比起你交互地使用它时,其默认输出格式是不同的(更简明些)。例
如,当交互式运行select distinct species from pet时,输出应为:
+---------+
| species |
+---------+
| bird |
| cat |
| dog |
| hamster |
| snake |
+---------+
但是当以批模式运行时,输出应为:
species
bird
cat
dog
hamster
snake
如果你想要在批模式中得到交互输出格式,使用mysql -t。为了回显以输出被执行的命令,使用
mysql -vvv。
你还可以使用源代码或 \.命令从mysql提示符运行脚本:
mysql> source filename;
mysql> \. filename
数据库备份
-- 删除数据库
drop database 数据库名(数据库中有横线时需用反引号引起来。``.否则会报错)
--导出 在cmd下而不是mysql下
mysqldum -u btsserver -p 数据库名 > e:/textout.sql -- 末尾不要加分号
shell> mysqldump [options] db_name [tbl_name ...] 恢复需要手动crate databases
shell> mysqldump [options] --databases db_name ... 恢复不需要手动创建数据库
shell> mysqldump [options] --all-databases 恢复不需要手动创建数据库
其他选项:
-e, --events: 备份事件调度器
-r, --routines: 备份存储过程和存储函数
--triggers: 备份表的触发器; --skip-triggers
--master-date[=value]
1: 记录为change master to 语句、语句不被注释
2: 记录为注释的change master to语句
基于二进制还原只能全库还原
--flush-logs: 日志滚动
锁定表完成后执行日志滚动
语法:
默认不带参数的导出,导出文本内容大概如下:创建数据库判断语句-删除表-创建表-锁表-禁用索引-插入数据-启用索引-解锁表。
usage: mysqldump [options] database [tables]
or mysqldump [options] --databases [options] db1 [db2 db3...]
or mysqldump [options] --all-databases [options]
插入测试数据
复制代码
create database db1 default charset utf8;
use db1;
create table a1(id int);
insert into a1() values(1),(2);
create table a2(id int);
insert into a2() values(2);
create table a3(id int);
insert into a3() values(3);
create database db2 default charset utf8;
use db2;
create table b1(id int);
insert into b1() values(1);
create table b2(id int);
insert into b2() values(2);
复制代码
1.导出所有数据库
该命令会导出包括系统数据库在内的所有数据库
mysqldump -uroot -proot --all-databases >/tmp/all.sql
2.导出db1、db2两个数据库的所有数据
mysqldump -uroot -proot --databases db1 db2 >/tmp/user.sql
3.导出db1中的a1、a2表
注意导出指定表只能针对一个数据库进行导出,且导出的内容中和导出数据库也不一样,导出指定表的导出文本中没有创建数据库的判断语句,只有删除表-创建表-导入数据
mysqldump -uroot -proot --databases db1 --tables a1 a2 >/tmp/db1.sql
4.条件导出,导出db1表a1中id=1的数据
如果多个表的条件相同可以一次性导出多个表
字段是整形
mysqldump -uroot -proot --databases db1 --tables a1 --where='id=1' >/tmp/a1.sql
字段是字符串,并且导出的sql中不包含drop table,create table
mysqldump -uroot -proot --no-create-info --databases db1 --tables a1 --where="id='a'" >/tmp/a1.sql
5.生成新的binlog文件,-f
有时候会希望导出数据之后生成一个新的binlog文件,只需要加上-f参数即可
mysqldump -uroot -proot --databases db1 -f >/tmp/db1.sql
6.只导出表结构不导出数据,--no-data
mysqldump -uroot -proot --no-data --databases db1 >/tmp/db1.sql
7.跨服务器导出导入数据
mysqldump --host=h1 -uroot -proot --databases db1 |mysql --host=h2 -uroot -proot db2
将h1服务器中的db1数据库的所有数据导入到h2中的db2数据库中,db2的数据库必须存在否则会报错
mysqldump --host=192.168.80.137 -uroot -proot -c --databases test |mysql --host=192.168.80.133 -uroot -proot test
加上-c参数可以启用压缩传递。
8.将主库的binlog位置和文件名追加到导出数据的文件中,--dump-slave
注意:--dump-slave命令如果当前服务器是从服务器那么使用该命令会执行stop slave来获取master binlog的文件和位置,等备份完后会自动执行start slave启动从服务器。但是如果是大的数据量备份会给从和主的延时变的更大,使用--dump-slave获取到的只是当前的从服务器的数据执行到的主的binglog的位置是(relay_mater_log_file,exec_master_log_pos),而不是主服务器当前的binlog执行的位置,主要是取决于主从的数据延时。
该参数在在从服务器上执行,相当于执行show slave status。当设置为1时,将会以change master命令输出到数据文件;设置为2时,会在change前加上注释。
该选项将会打开--lock-all-tables,除非--single-transaction被指定。
在执行完后会自动关闭--lock-tables选项。--dump-slave默认是1
mysqldump -uroot -proot --dump-slave=1 --databases db1 >/tmp/db1.sql
mysqldump -uroot -proot --dump-slave=2 --database db1 >/tmp/db1.sql
9.将当前服务器的binlog的位置和文件名追加到输出文件,--master-data
该参数和--dump-slave方法一样,只是它是记录的是当前服务器的binlog,相当于执行show master status,状态(file,position)的值。
注意:--master-data不会停止当前服务器的主从服务
10.--opt
等同于--add-drop-table, --add-locks, --create-options, --quick, --extended-insert, --lock-tables, --set-charset, --disable-keys 该选项默认开启, 可以用--skip-opt禁用.
mysqldump -uroot -p --host=localhost --all-databases --opt
11.保证导出的一致性状态--single-transaction
该选项在导出数据之前提交一个begin sql语句,begin 不会阻塞任何应用程序且能保证导出时数据库的一致性状态。它只适用于多版本存储引擎(它不显示加锁通过判断版本来对比数据),仅innodb。本选项和--lock-tables 选项是互斥的,因为lock tables 会使任何挂起的事务隐含提交。要想导出大表的话,应结合使用--quick 选项。
--quick, -q
不缓冲查询,直接导出到标准输出。默认为打开状态,使用--skip-quick取消该选项。
12.--lock-tables, -l
开始导出前,锁定所有表。用read local锁定表以允许myisam表并行插入。对于支持事务的表例如innodb和bdb,--single-transaction是一个更好的选择,因为它根本不需要锁定表。
请注意当导出多个数据库时,--lock-tables分别为每个数据库锁定表。因此,该选项不能保证导出文件中的表在数据库之间的逻辑一致性。不同数据库表的导出状态可以完全不同。
13.导出存储过程和自定义函数--routines, -r
mysqldump -uroot -p --host=localhost --all-databases --routines
14.压缩备份
压缩备份
mysqldump -uroot -proot --databases abc 2>/dev/null |gzip >/abc.sql.gz
还原
gunzip -c abc.sql.gz |mysql -uroot -proot abc
参数说明:
复制代码
--all-databases , -a
导出全部数据库。
mysqldump -uroot -p --all-databases
--all-tablespaces , -y
导出全部表空间。
mysqldump -uroot -p --all-databases --all-tablespaces
--no-tablespaces , -y
不导出任何表空间信息。
mysqldump -uroot -p --all-databases --no-tablespaces
--add-drop-database
每个数据库创建之前添加drop数据库语句。
mysqldump -uroot -p --all-databases --add-drop-database
--add-drop-table
每个数据表创建之前添加drop数据表语句。(默认为打开状态,使用--skip-add-drop-table取消选项)
mysqldump -uroot -p --all-databases (默认添加drop语句)
mysqldump -uroot -p --all-databases –skip-add-drop-table (取消drop语句)
--add-locks
在每个表导出之前增加lock tables并且之后unlock table。(默认为打开状态,使用--skip-add-locks取消选项)
mysqldump -uroot -p --all-databases (默认添加lock语句)
mysqldump -uroot -p --all-databases –skip-add-locks (取消lock语句)
--allow-keywords
允许创建是关键词的列名字。这由表名前缀于每个列名做到。
mysqldump -uroot -p --all-databases --allow-keywords
--apply-slave-statements
在'change master'前添加'stop slave',并且在导出的最后添加'start slave'。
mysqldump -uroot -p --all-databases --apply-slave-statements
--character-sets-dir
字符集文件的目录
mysqldump -uroot -p --all-databases --character-sets-dir=/usr/local/mysql/share/mysql/charsets
--comments
附加注释信息。默认为打开,可以用--skip-comments取消
mysqldump -uroot -p --all-databases (默认记录注释)
mysqldump -uroot -p --all-databases --skip-comments (取消注释)
--compatible
导出的数据将和其它数据库或旧版本的mysql 相兼容。值可以为ansi、mysql323、mysql40、postgresql、oracle、mssql、db2、maxdb、no_key_options、no_tables_options、no_field_options等,
要使用几个值,用逗号将它们隔开。它并不保证能完全兼容,而是尽量兼容。
mysqldump -uroot -p --all-databases --compatible=ansi
--compact
导出更少的输出信息(用于调试)。去掉注释和头尾等结构。可以使用选项:--skip-add-drop-table --skip-add-locks --skip-comments --skip-disable-keys
mysqldump -uroot -p --all-databases --compact
--complete-insert, -c
使用完整的insert语句(包含列名称)。这么做能提高插入效率,但是可能会受到max_allowed_packet参数的影响而导致插入失败。
mysqldump -uroot -p --all-databases --complete-insert
--compress, -c
在客户端和服务器之间启用压缩传递所有信息
mysqldump -uroot -p --all-databases --compress
--create-options, -a
在create table语句中包括所有mysql特性选项。(默认为打开状态)
mysqldump -uroot -p --all-databases
--databases, -b
导出几个数据库。参数后面所有名字参量都被看作数据库名。
mysqldump -uroot -p --databases test mysql
--debug
输出debug信息,用于调试。默认值为:d:t,/tmp/mysqldump.trace
mysqldump -uroot -p --all-databases --debug
mysqldump -uroot -p --all-databases --debug=” d:t,/tmp/debug.trace”
--debug-check
检查内存和打开文件使用说明并退出。
mysqldump -uroot -p --all-databases --debug-check
--debug-info
输出调试信息并退出
mysqldump -uroot -p --all-databases --debug-info
--default-character-set
设置默认字符集,默认值为utf8
mysqldump -uroot -p --all-databases --default-character-set=utf8
--delayed-insert
采用延时插入方式(insert delayed)导出数据
mysqldump -uroot -p --all-databases --delayed-insert
--delete-master-logs
master备份后删除日志. 这个参数将自动激活--master-data。
mysqldump -uroot -p --all-databases --delete-master-logs
--disable-keys
对于每个表,用/*!40000 alter table tbl_name disable keys */;和/*!40000 alter table tbl_name enable keys */;语句引用insert语句。这样可以更快地导入dump出来的文件,因为它是在插入所有行后创建索引的。该选项只适合myisam表,默认为打开状态。
mysqldump -uroot -p --all-databases
--dump-slave
该选项将主的binlog位置和文件名追加到导出数据的文件中(show slave status)。设置为1时,将会以change master命令输出到数据文件;设置为2时,会在change前加上注释。该选项将会打开--lock-all-tables,除非--single-transaction被指定。该选项会自动关闭--lock-tables选项。默认值为0。
mysqldump -uroot -p --all-databases --dump-slave=1
mysqldump -uroot -p --all-databases --dump-slave=2
--master-data
该选项将当前服务器的binlog的位置和文件名追加到输出文件中(show master status)。如果为1,将会输出change master 命令;如果为2,输出的change master命令前添加注释信息。该选项将打开--lock-all-tables 选项,除非--single-transaction也被指定(在这种情况下,全局读锁在开始导出时获得很短的时间;其他内容参考下面的--single-transaction选项)。该选项自动关闭--lock-tables选项。
mysqldump -uroot -p --host=localhost --all-databases --master-data=1;
mysqldump -uroot -p --host=localhost --all-databases --master-data=2;
--events, -e
导出事件。
mysqldump -uroot -p --all-databases --events
--extended-insert, -e
使用具有多个values列的insert语法。这样使导出文件更小,并加速导入时的速度。默认为打开状态,使用--skip-extended-insert取消选项。
mysqldump -uroot -p --all-databases
mysqldump -uroot -p --all-databases--skip-extended-insert (取消选项)
--fields-terminated-by
导出文件中忽略给定字段。与--tab选项一起使用,不能用于--databases和--all-databases选项
mysqldump -uroot -p test test --tab=”/home/mysql” --fields-terminated-by=”#”
--fields-enclosed-by
输出文件中的各个字段用给定字符包裹。与--tab选项一起使用,不能用于--databases和--all-databases选项
mysqldump -uroot -p test test --tab=”/home/mysql” --fields-enclosed-by=”#”
--fields-optionally-enclosed-by
输出文件中的各个字段用给定字符选择性包裹。与--tab选项一起使用,不能用于--databases和--all-databases选项
mysqldump -uroot -p test test --tab=”/home/mysql” --fields-enclosed-by=”#” --fields-optionally-enclosed-by =”#”
--fields-escaped-by
输出文件中的各个字段忽略给定字符。与--tab选项一起使用,不能用于--databases和--all-databases选项
mysqldump -uroot -p mysql user --tab=”/home/mysql” --fields-escaped-by=”#”
--flush-logs
开始导出之前刷新日志。
请注意:假如一次导出多个数据库(使用选项--databases或者--all-databases),将会逐个数据库刷新日志。除使用--lock-all-tables或者--master-data外。在这种情况下,日志将会被刷新一次,相应的所以表同时被锁定。因此,如果打算同时导出和刷新日志应该使用--lock-all-tables 或者--master-data 和--flush-logs。
mysqldump -uroot -p --all-databases --flush-logs
--flush-privileges
在导出mysql数据库之后,发出一条flush privileges 语句。为了正确恢复,该选项应该用于导出mysql数据库和依赖mysql数据库数据的任何时候。
mysqldump -uroot -p --all-databases --flush-privileges
--force
在导出过程中忽略出现的sql错误。
mysqldump -uroot -p --all-databases --force
--help
显示帮助信息并退出。
mysqldump --help
--hex-blob
使用十六进制格式导出二进制字符串字段。如果有二进制数据就必须使用该选项。影响到的字段类型有binary、varbinary、blob。
mysqldump -uroot -p --all-databases --hex-blob
--host, -h
需要导出的主机信息
mysqldump -uroot -p --host=localhost --all-databases
--ignore-table
不导出指定表。指定忽略多个表时,需要重复多次,每次一个表。每个表必须同时指定数据库和表名。例如:--ignore-table=database.table1 --ignore-table=database.table2 ……
mysqldump -uroot -p --host=localhost --all-databases --ignore-table=mysql.user
--include-master-host-port
在--dump-slave产生的'change master to..'语句中增加'master_host=<host>,master_port=<port>'
mysqldump -uroot -p --host=localhost --all-databases --include-master-host-port
--insert-ignore
在插入行时使用insert ignore语句.
mysqldump -uroot -p --host=localhost --all-databases --insert-ignore
--lines-terminated-by
输出文件的每行用给定字符串划分。与--tab选项一起使用,不能用于--databases和--all-databases选项。
mysqldump -uroot -p --host=localhost test test --tab=”/tmp/mysql” --lines-terminated-by=”##”
--lock-all-tables, -x
提交请求锁定所有数据库中的所有表,以保证数据的一致性。这是一个全局读锁,并且自动关闭--single-transaction 和--lock-tables 选项。
mysqldump -uroot -p --host=localhost --all-databases --lock-all-tables
--lock-tables, -l
开始导出前,锁定所有表。用read local锁定表以允许myisam表并行插入。对于支持事务的表例如innodb和bdb,--single-transaction是一个更好的选择,因为它根本不需要锁定表。
请注意当导出多个数据库时,--lock-tables分别为每个数据库锁定表。因此,该选项不能保证导出文件中的表在数据库之间的逻辑一致性。不同数据库表的导出状态可以完全不同。
mysqldump -uroot -p --host=localhost --all-databases --lock-tables
--log-error
附加警告和错误信息到给定文件
mysqldump -uroot -p --host=localhost --all-databases --log-error=/tmp/mysqldump_error_log.err
--max_allowed_packet
服务器发送和接受的最大包长度。
mysqldump -uroot -p --host=localhost --all-databases --max_allowed_packet=10240
--net_buffer_length
tcp/ip和socket连接的缓存大小。
mysqldump -uroot -p --host=localhost --all-databases --net_buffer_length=1024
--no-autocommit
使用autocommit/commit 语句包裹表。
mysqldump -uroot -p --host=localhost --all-databases --no-autocommit
--no-create-db, -n
只导出数据,而不添加create database 语句。
mysqldump -uroot -p --host=localhost --all-databases --no-create-db
--no-create-info, -t
只导出数据,而不添加create table 语句。
mysqldump -uroot -p --host=localhost --all-databases --no-create-info
--no-data, -d
不导出任何数据,只导出数据库表结构。
mysqldump -uroot -p --host=localhost --all-databases --no-data
--no-set-names, -n
等同于--skip-set-charset
mysqldump -uroot -p --host=localhost --all-databases --no-set-names
--opt
等同于--add-drop-table, --add-locks, --create-options, --quick, --extended-insert, --lock-tables, --set-charset, --disable-keys 该选项默认开启, 可以用--skip-opt禁用.
mysqldump -uroot -p --host=localhost --all-databases --opt
--order-by-primary
如果存在主键,或者第一个唯一键,对每个表的记录进行排序。在导出myisam表到innodb表时有效,但会使得导出工作花费很长时间。
mysqldump -uroot -p --host=localhost --all-databases --order-by-primary
--password, -p
连接数据库密码
--pipe(windows系统可用)
使用命名管道连接mysql
mysqldump -uroot -p --host=localhost --all-databases --pipe
--port, -p
连接数据库端口号
--protocol
使用的连接协议,包括:tcp, socket, pipe, memory.
mysqldump -uroot -p --host=localhost --all-databases --protocol=tcp
--quick, -q
不缓冲查询,直接导出到标准输出。默认为打开状态,使用--skip-quick取消该选项。
mysqldump -uroot -p --host=localhost --all-databases
mysqldump -uroot -p --host=localhost --all-databases --skip-quick
--quote-names,-q
使用(`)引起表和列名。默认为打开状态,使用--skip-quote-names取消该选项。
mysqldump -uroot -p --host=localhost --all-databases
mysqldump -uroot -p --host=localhost --all-databases --skip-quote-names
--replace
使用replace into 取代insert into.
mysqldump -uroot -p --host=localhost --all-databases --replace
--result-file, -r
直接输出到指定文件中。该选项应该用在使用回车换行对(\\r\\n)换行的系统上(例如:dos,windows)。该选项确保只有一行被使用。
mysqldump -uroot -p --host=localhost --all-databases --result-file=/tmp/mysqldump_result_file.txt
--routines, -r
导出存储过程以及自定义函数。
mysqldump -uroot -p --host=localhost --all-databases --routines
--set-charset
添加'set names default_character_set'到输出文件。默认为打开状态,使用--skip-set-charset关闭选项。
mysqldump -uroot -p --host=localhost --all-databases
mysqldump -uroot -p --host=localhost --all-databases --skip-set-charset
--single-transaction
该选项在导出数据之前提交一个begin sql语句,begin 不会阻塞任何应用程序且能保证导出时数据库的一致性状态。它只适用于多版本存储引擎,仅innodb。本选项和--lock-tables 选项是互斥的,因为lock tables 会使任何挂起的事务隐含提交。要想导出大表的话,应结合使用--quick 选项。
mysqldump -uroot -p --host=localhost --all-databases --single-transaction
--dump-date
将导出时间添加到输出文件中。默认为打开状态,使用--skip-dump-date关闭选项。
mysqldump -uroot -p --host=localhost --all-databases
mysqldump -uroot -p --host=localhost --all-databases --skip-dump-date
--skip-opt
禁用–opt选项.
mysqldump -uroot -p --host=localhost --all-databases --skip-opt
--socket,-s
指定连接mysql的socket文件位置,默认路径/tmp/mysql.sock
mysqldump -uroot -p --host=localhost --all-databases --socket=/tmp/mysqld.sock
--tab,-t
为每个表在给定路径创建tab分割的文本文件。注意:仅仅用于mysqldump和mysqld服务器运行在相同机器上。注意使用--tab不能指定--databases参数
mysqldump -uroot -p --host=localhost test test --tab="/home/mysql"
--tables
覆盖--databases (-b)参数,指定需要导出的表名,在后面的版本会使用table取代tables。
mysqldump -uroot -p --host=localhost --databases test --tables test
--triggers
导出触发器。该选项默认启用,用--skip-triggers禁用它。
mysqldump -uroot -p --host=localhost --all-databases --triggers
--tz-utc
在导出顶部设置时区time_zone='+00:00' ,以保证在不同时区导出的timestamp 数据或者数据被移动其他时区时的正确性。
mysqldump -uroot -p --host=localhost --all-databases --tz-utc
--user, -u
指定连接的用户名。
--verbose, --v
输出多种平台信息。
--version, -v
输出mysqldump版本信息并退出
--where, -w
只转储给定的where条件选择的记录。请注意如果条件包含命令解释符专用空格或字符,一定要将条件引用起来。
mysqldump -uroot -p --host=localhost --all-databases --where=” user=’root’”
--xml, -x
导出xml格式.
mysqldump -uroot -p --host=localhost --all-databases --xml
--plugin_dir
客户端插件的目录,用于兼容不同的插件版本。
mysqldump -uroot -p --host=localhost --all-databases --plugin_dir=”/usr/local/lib/plugin”
--default_auth
客户端插件默认使用权限。
mysqldump -uroot -p --host=localhost --all-databases --default-auth=”/usr/local/lib/plugin/<plugin>”
复制代码
错误处理
1.unknown option '--no-beep'
第一种方法:删除my.ini[client]下的 no-beep 参数;
第二种方法:在 mysqldump 后加--no-defaults参数 。
总结
文章中列举了一些常用的导出操作,还有很多其它的参数也会经常用到,包括“--add-drop-database”,“--apply-slave-statements”,“--triggers”等。客户端的导入导出功能也是不错的选择,比如workbench、navicat;其中navicat的导出向导中可以有很多文件格式可以选择。
--tab的快速导出导入数据是个不错的方法,它会在指定的目录下生成一个sql表结构文件和一个text数据文件
-- 数据库的导入
把备份的所有数据文件还原:
mysql -u root -p < all_database_sql.sql,这里不需要指定库,因为是全部数据库
mysql -u root -p mysql < mysql_database_sql.sql #这里就需要指定是mysql库了