数据库3

一,视图

视图是一个虚拟的表,其内容由查询定义,同真实的表一样,视图包含一系列带有名称的列和行数据

视图有如下特点:

1,视图的列可以来自不同的表,是表的抽象和逻辑意义上建立的新关系

2,视图是由基本表产生的表

3,视图的建立不影响基本表

4,对视图内容的更新(添加,删除和修改)直接影响基本表

5,当视图来自等多个基本表时,不允许添加和删除数据

 

创建视图:

create view 视图名 as 添加的查询语句

CREATE VIEW d1 as SELECT * FROM person where id in (1,3,5);

使用视图

select * from 视图名

SELECT * FROM d1;

 

更新视图

alter view 视图名 as语句

ALTER view  d1 as SELECT * FROM person where id in (1,3);

删除视图

drop view 视图名

drop view d1;

二 触发器

触发器就是监视某种情况,并触发某种操作

创建触发器

创建触发器的四大要素:

1 监视地点(table,表名)

2, 监视事件(insert,update,delete)

3,触发时间(after,before)

4,触发事件(insert,update,delete)

CREATE TRIGGER 触发器名 after\before  INSERT\update\delete on 表名
for EACH ROW
BEGIN
语句
END

 

insert into b2(name,num) values('AK47',3);

 

create trigger tg1 after insert on  b2
for each row
begin    
  update b1 set num = num -3 where id = 2;
end

为了不把变量写死

create trigger tg1 after insert on  b2
for each row
begin    
  update b1 set num = num -new.num where id = new.gid;
end

如果删除后的数据,可以用old

create trigger tg3 afert delete  on order_table
for each row
bigen
    update goods set num = num + old.much where id = old.gid;-- (注意这边的变化)
end

 

删除触发器

DROP TRIGGER tg1;

 

当同一个数据要增加或者减少触发器该这样写:

create trigger tg4 after update on order_table
for each row
begin
    update goods set num = num+old.much-new.much where id = old.gid;
end

三,存储过程

存储过程类似于函数,简单地说存储过程是为了完成某个数据库中特定功能而编写的的

语句集合,该语句集包括sql语句(对数据的增删改查),条件语句和循环语句。

1,创建存储过程

CREATE procedure p1()
BEGIN

SELECT * FROM person;
END

 

2,查看现有的存储过程

show procedure status;

3,删除存储过程

drop procedure p1;

4,调用存储过程

call p1();

5,有参数的存储过程

CREATE procedure p1(inout n int)
 BEGIN
declare sum int DEFAULT 0;   设置总变量,并且默认值为0
declare i int;      声明变量i,类型为int
set i =0;            设置变量i初始值为0
WHILE i<=n DO          开始循环
    set sum=sum+i;
    set i=i+1;
end WHILE;
SELECT sum;            提供运算结果
set n=sum;              将计算的结果提供给输出的变量n;
END;

set @b=100;
call p1(@b);
SELECT @b;

存储过程的优点:

1,存储过程增强了sql语言的灵活性

存储过程可以使用控制语句编写,可以完成复杂的判断和较复杂的运算,有很强的灵活性:

2,减少网络流量,降低了网络负载。

存储过程在服务器端创建成功后,只需要调用该存储过程即可,而传统的做法是每次都将大量的

sql语句通过网络发送到数据库服务器端然后在执行。

3,存储过程只在创造时进行编译,以后每次执行存储过程,都不需要重新编译。

一般sql语句每执行一次就编译一次,所以使用存储过程可提高数据库执行速度。

 

存储过程的缺点:

1,扩展功能不方便,

2,不便于系统后期维护

四 函数

mysql提供的内建函数

  1 一、数学函数
  2     ROUND(x,y)
  3         返回参数x的四舍五入的有y位小数的值
  4         
  5     RAND()
  6         返回0到1内的随机值,可以通过提供一个参数(种子)使RAND()随机数生成器生成一个指定的值。
  7 
  8 二、聚合函数(常用于GROUP BY从句的SELECT查询中)
  9     AVG(col)返回指定列的平均值
 10     COUNT(col)返回指定列中非NULL值的个数
 11     MIN(col)返回指定列的最小值
 12     MAX(col)返回指定列的最大值
 13     SUM(col)返回指定列的所有值之和
 14     GROUP_CONCAT(col) 返回由属于一组的列值连接组合而成的结果    
 15     
 16 三、字符串函数
 17 
 18     CHAR_LENGTH(str)
 19         返回值为字符串str 的长度,长度的单位为字符。一个多字节字符算作一个单字符。
 20     CONCAT(str1,str2,...)
 21         字符串拼接
 22         如有任何一个参数为NULL ,则返回值为 NULL。
 23     CONCAT_WS(separator,str1,str2,...)
 24         字符串拼接(自定义连接符)
 25         CONCAT_WS()不会忽略任何空字符串。 (然而会忽略所有的 NULL)。
 26 
 27     FORMAT(X,D)
 28         将数字X 的格式写为'#,###,###.##',以四舍五入的方式保留小数点后 D 位, 并将结果以字符串的形式返回。若  D 为 0, 则返回结果不带有小数点,或不含小数部分。
 29         例如:
 30             SELECT FORMAT(12332.1,4); 结果为: '12,332.1000'
 31     
 32     INSERT(str,pos,len,newstr)
 33         在str的指定位置插入字符串
 34             pos:要替换位置其实位置
 35             len:替换的长度
 36             newstr:新字符串
 37         例如:
 38             SELECT INSERT('abcd',1,2,'tt'); 结果为: 'ttcd'
 39             SELECT INSERT('abcd',1,4,'tt'); 结果为: 'tt'
 40         特别的:
 41             如果pos超过原字符串长度,则返回原字符串
 42             如果len超过原字符串长度,则由新字符串完全替换
 43     
 44     INSTR(str,substr)
 45         返回字符串 str 中子字符串的第一个出现位置。
 46 
 47     LEFT(str,len)
 48         返回字符串str 从开始的len位置的子序列字符。
 49         例如:
 50             SELECT INSTR('abc','c'); 结果为: 3
 51             SELECT INSTR('abc','d'); 结果为: 0
 52             
 53     LOWER(str)
 54         变小写
 55 
 56     UPPER(str)
 57         变大写
 58    
 59     REVERSE(str)
 60         返回字符串 str ,顺序和字符顺序相反。
 61         例如:
 62             SELECT REVERSE('1234567') 结果为:7654321
 63             
 64     SUBSTRING(str,pos) , SUBSTRING(str FROM pos) SUBSTRING(str,pos,len) , SUBSTRING(str FROM pos FOR len)
 65         不带有len 参数的格式从字符串str返回一个子字符串,起始于位置 pos。带有len参数的格式从字符串str返回一个长度同len字符相同的子字符串,起始于位置 pos。 使用 FROM的格式为标准 SQL 语法。也可能对pos使用一个负值。假若这样,则子字符串的位置起始于字符串结尾的pos 字符,而不是字符串的开头位置。在以下格式的函数中可以对pos 使用一个负值。
 66 
 67         mysql> SELECT SUBSTRING('Quadratically',5); -- 从第5位开始截取
 68             -> 'ratically'
 69 
 70         mysql> SELECT SUBSTRING('foobarbar' FROM 4); -- 从第4位开始截取
 71             -> 'barbar'
 72 
 73         mysql> SELECT SUBSTRING('Quadratically',5,6); --从第5位开始截取,截取6个长度
 74             -> 'ratica'
 75 
 76         mysql> SELECT SUBSTRING('Sakila', -3);    -- 从倒数第3位开始截取
 77             -> 'ila'
 78 
 79         mysql> SELECT SUBSTRING('Sakila', -5, 3); -- 从倒数第5位开始截取,截取3个长度
 80             -> 'aki'
 81             
 82 四、日期和时间函数
 83     CURDATE()或CURRENT_DATE() 返回当前的日期
 84     CURTIME()或CURRENT_TIME() 返回当前的时间
 85     DAYOFWEEK(date)   返回date所代表的一星期中的第几天(1~7)
 86     DAYOFMONTH(date)  返回date是一个月的第几天(1~31)
 87     DAYOFYEAR(date)   返回date是一年的第几天(1~366)
 88     DAYNAME(date)   返回date的星期名,如:SELECT DAYNAME(CURRENT_DATE);
 89     FROM_UNIXTIME(ts,fmt)  根据指定的fmt格式,格式化UNIX时间戳ts
 90     HOUR(time)   返回time的小时值(0~23)
 91     MINUTE(time)   返回time的分钟值(0~59)
 92     MONTH(date)   返回date的月份值(1~12)
 93     MONTHNAME(date)   返回date的月份名,如:SELECT MONTHNAME(CURRENT_DATE);
 94     NOW()    返回当前的日期和时间
 95     QUARTER(date)   返回date在一年中的季度(1~4),如SELECT QUARTER(CURRENT_DATE);
 96     WEEK(date)   返回日期date为一年中第几周(0~53)
 97     YEAR(date)   返回日期date的年份(1000~9999)
 98     
 99     重点:
100     DATE_FORMAT(date,format) 根据format字符串格式化date值
101 
102        mysql> SELECT DATE_FORMAT('2009-10-04 22:23:00', '%W %M %Y');
103         -> 'Sunday October 2009'
104        mysql> SELECT DATE_FORMAT('2007-10-04 22:23:00', '%H:%i:%s');
105         -> '22:23:00'
106        mysql> SELECT DATE_FORMAT('1900-10-04 22:23:00',
107         ->                 '%D %y %a %d %m %b %j');
108         -> '4th 00 Thu 04 10 Oct 277'
109        mysql> SELECT DATE_FORMAT('1997-10-04 22:23:00',
110         ->                 '%H %k %I %r %T %S %w');
111         -> '22 22 10 10:23:00 PM 22:23:00 00 6'
112        mysql> SELECT DATE_FORMAT('1999-01-01', '%X %V');
113         -> '1998 52'
114        mysql> SELECT DATE_FORMAT('2006-06-00', '%d');
115         -> '00'
116         
117 五、加密函数
118     MD5()    
119         计算字符串str的MD5校验和
120         例如:
121             SELECT MD5('1234') 结果为:81dc9bdb52d04dc20036dbd8313ed055
122     PASSWORD(str)   
123         返回字符串str的加密版本,这个加密过程是不可逆转的
124         例如:
125             SELECT PASSWORD('1234') 结果为:*A4B6157319038724E3560894F7F932C8886EBFCF
126         
127 六、控制流函数            
128     CASE WHEN[test1] THEN [result1]...ELSE [default] END
129         如果testN是真,则返回resultN,否则返回default
130     CASE [test] WHEN[val1] THEN [result]...ELSE [default]END  
131         如果test和valN相等,则返回resultN,否则返回default
132 
133     IF(test,t,f)   
134         如果test是真,返回t;否则返回f
135 
136     IFNULL(arg1,arg2) 
137         如果arg1不是空,返回arg1,否则返回arg2
138         例如:
139             SELECT IFNULL('bbb','abc'); 结果为: bbb
140             SELECT IFNULL(null,'abc');  结果为: abc
141 
142     NULLIF(arg1,arg2) 
143         如果arg1=arg2返回NULL;否则返回arg1
144         例如:
145             SELECT NULLIF('bbb','bbb');结果为: null
146             SELECT NULLIF('aaa','bbb');结果为: aaa
View Code

 1,自定义函数

CREATE function func(a int,b int)
returns INT
BEGIN
declare sum int default 0;
set sum =a+b;
return(sum);
END

2,调用函数

SELECT func(1,8);   直接调用

SELECT func(3,5),id FROM person;   在sql语句中调用

3,删除自定义函数

drop function func;

函数与存储过程的区别:

函数:                                                 存储过程:

一般用于计算数据                                                     完成特定的任务

声明为function                                                               声明为procedure

需要描述返回类型,且拍                                     无返回类型,可通过out  in out 参数返回多个值

了/sql块中至少有一个 有效的reture语句

不能独立运行,必须作为表达式一部分                 可作为一个独立的pl/sql语句运行

在dml和dql中可调用函数                                          在dml和dql中不可调用过程

 

五,事物

什么是事物,一组sql语句批量执行,要么全部执行成功,要么全部执行成功

保持数据的一致性

 

1,事物的特性,

原子性:对其数据的修改,要么全部执行,要么全都不执行

一致性:数据库原来有什么样的约束,事物执行之后还需要存在这样的约束,所有规则都必须应用于事物的修改,以保持原有数据的完整性。

隔离性:一个事物不能知道另外一个事物的执行情况

持久性;即使出现致命的系统故障也将一直保持,

注意:

在mysql中只有使用了innodb数据库引擎或表才支持事物

事物处理可以用来维护数据库的完整性,保证成批的sql语句要么全部执行,要么全部不执行。

事物用来管理insert,update ,delete语句,

事物控制语句

1,begin 或 start transaction;显示开启一个事物

2,commit;也可以使用commit work不过二者是等价的

commit 会提交事物,并使已对数据库进行的所有修改,3

3,rollback ;有可以使用rollback,work,不过二者是等价的。回滚会结束用户的事物,并撤销正在进行的所有未提交的修改

4,savepoint  保存点,可以把一个事物分割成几部分,在执行rollback时,可以指定在什么位置上

进行回滚操作

注意,set,autocommit=0  禁止自动提交和set autocommit=1  开启自动提交

实例演示,

创建表

CREATE TABLE ti(id int(50) not null auto_increment primary key,
name varchar(50) not null,
money DOUBLE(5,2) not null)


#double是同时设置长度和小数点的位数

插入数据

INSERT into ti (name,money) values('甘琦',250),('赵志祥',300);

开启事物

start transaction; -- 开启事物
 --  执行sql语句操作
 update account set money = money - 500 where id ='1';  
 update account set money = money+500 where id = '2';
 
commit;  -- 手动提交事物
rollback; -- 回滚事物
 
--  查看结果
select * from account;

保存点使用

START TRANSACTION ;
 
insert into account (name,money) values('李元芳',1000);
 
SAVEPOINT s1; -- 设置保存点
 
insert into account (name,money) values('张桂枝',1500);
 
ROLLBACK to s1; -- 事物回滚到保存点<br>COMMIT; --提交事物

六,数据锁

1. 锁的基本概念

  当并发事务同时访问一个资源时,有可能导致数据不一致,因此需要一种机制来将数据访问顺序化,以保证数据库数据的一致性。

2. 锁的基本类型

  多个事务同时读取一个对象的时候,是不会有冲突的。同时读和写,或者同时写才会产生冲突。因此为了提高数据库的并发性能,通常会定义两种锁:共享锁和排它锁。

  2.1 共享锁(Shared Lock,也叫S锁)

    共享锁(S)表示对数据进行读操作。因此多个事务可以同时为一个对象加共享锁。(如果试衣间的门还没被锁上,顾客都能够同时进去参观)

  2.2 排他锁(Exclusive Lock,也叫X)

    排他锁(X)表示对数据进行写操作。如果一个事务对 对象加了排他锁,其他事务就不能再给它加任何锁了。(某个顾客把试衣间从里面反锁了,其他顾客想要使用这个试衣间,就只有等待锁从里面给打开了).

 

3. 实际开发中常见的两种锁:

  3.1悲观锁 顾名思义,就是很悲观,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁,这样别人想拿这个数据就会block(阻塞)直到它拿到锁。传统的关系型数据库里边就用到了很多这种锁机制.

注意:要使用悲观锁,我们必须关闭mysql数据库的自动提交属性.因为MySQL默认使用autocommit模式,也就是说,当你执行一个更新操作后,MySQL会立刻将结果进行提交。关闭自动提交命令为:set autocommit=0;

-- 窗口1 用户进行充值

-- 充值前 先查看余额
set @m=0;

SELECT money into @m from account where id = 1;

select @m;

-- 看到余额后 充值100 块
update account set money = @m + 100 where id = 1;

SELECT * from account;

--------------------------------------------------------------
-- 窗口2 用户进行取款

-- 取款前 先查看余额
set @m=0;

SELECT money into @m from account where id = 1;

select @m;

-- 看到余额后 取款100 块
update account set money = @m - 100 where id = 1;

SELECT * from account;

示例
例子
-- 0.开始事务
start transaction;
 
-- 1.查询账户余额
set @m = 0; -- 账户余额
select money into @m from account where id = 1 for update;
select @m;
 
-- 2.修改账户余额
update account set money = @m -100 where id = 1;
 
select * FROM account where id = 1;
-- 3. 提交事务
commit;
View Code
0.开始事务
start transaction;
 
-- 1.查询账户余额
set @m = 0; -- 账户余额
select money into @m from account where id = 1 for update;
select @m;
 
-- 2.修改账户余额
update account set money = @m +100 where id = 1;
 
select * FROM account where id = 1;
-- 3. 提交事务
commit;
另外页面查询

注意:

会发现当前查询会进入到等待状态,不会显示出数据,当上面的sql执行完毕提交事物后,当前sql才会显示结果.

注意1:在使用悲观锁时,如果表中没有指定主键,则会进行锁表操作.

注意2: 悲观锁的确保了数据的安全性,在数据被操作的时候锁定数据不被访问,但是这样会带来很大的性能问题。因此悲观锁在实际开发中使用是相对比较少的。  

   3.2 乐观锁, 顾名思义,就是很乐观,每次去拿数据的时候都认为别人不会修改,所以不会上锁,但是在更新的时候会判断一下在此期间别人有没有去更新这个数据,可以使用版本号等机制。 

使用乐观锁的两种方式:

  1.使用数据版本(Version)记录机制实现,这是乐观锁最常用的一种实现 方式。何谓数据版本?即为数据增加一个版本标识,一般是通过为数据库表增加一个数字类型的 “version” 字段来实现。当读取数据时,将version字段的值一同读出,数据每更新一次,对此version值加一。当我们提交更新的时候,判断数据库表对应记录 的当前版本信息与第一次取出来的version值进行比对,如果数据库表当前版本号与第一次取出来的version值相等,则予以更新,否则认为是过期数 据。

 代码示例:

-- 1.查询账户余额
set @m = 0; -- 账户余额
select money into @m from account where id = 1 ;
select @m;
-- 2.查询版本号
set @version = 0; -- 版本号
select version into @version from account where id = 1 ;
select @version;
 
-- 3.修改账户余额
update account set money = @m -100,version=version+1 where id = 1 and version = @version;
 
select * FROM account where id = 1;
View Code

 2.乐观锁定的第二种实现方式和第一种差不多,同样是在需要乐观锁控制的table中增加一个字段,名称无所谓,字段类型使用时间戳 (datatime), 和上面的version类似,也是在更新提交的时候检查当前数据库中数据的时间戳和自己更新前取到的时间戳进行对比,如果一致则OK,否则就是版本冲突。

 

悲观锁与乐观锁的优缺点:

  两种锁各有其有点缺点,不能单纯的讲哪个更好.

    乐观锁适用于写入比较少的情况下,即冲突真的很少发生的时候,这样可以省去了锁的开销,加大了系统的整个吞吐量。

    但如果经常产生冲突,上层应用会不断的进行重试操作,这样反倒是降低了性能,所以这种情况下用悲观锁就比较合适.

 七.数据库备份

使用mysqldump实现逻辑备份

5.6版本的需要加上--no-defaults -h 192.168.13.56 

单库备份

mysqldump --no-defaults  -h 192.168.13.56 -uroot -p123456 a1 person >d:/person.sql
mysqldump --no-defaults 192.168.13.56 -uroot -p123456 a1 dept tdb_goods > d:/12w-34e.sql


备份的是库,但是只备份库里的两张表

 

多库备份

mysqldump --no-defaults 192.168.13.56 -uroot -p123456 多个库名 > d:/ee.sql

 

 

备份所有

mysqldump --no-defaults 192.168.13.56 -uroot -p123456 --all-datebases > d:/ee.sql
--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. 删除my.ini [client]下的 no-beep 参数;
2. 在 mysqldump 后加--no-defaults参数,即:mysqldump --no-defualts -h主机IP -u用户名 -p密码 数据库 > xxx.sql 。

恢复逻辑备份

 

posted @ 2018-12-17 13:58  许光宗  阅读(167)  评论(0编辑  收藏  举报