1.事务
1.1 定义
事务:数据库事务通常指对数据库进行读或写的一个操作过程。有两个目的,第一个是为数据库操作提供了一个从失败中恢复到正常状态的方法,同时提供了数据库即使在异常状态下仍能保持一致性的方法;第二个是当多个应用程序在并发访问数据库时,可以在这些应用程序之间提供一个隔离方法,以防止彼此的操作互相干扰。
1.2 事务的特性(ACID)
1.原子性(Atomicity):事务必须是原子工作单元,一个事务中的所有语句,应该做到:要么全做,要么一个都不做;
2.一致性(Consistency):让数据保持逻辑上的“合理性”,比如:小明给小红打10000块钱,既要让小明的账户减少10000,又要让小红的账户上增加10000块钱;
3.隔离性(Isolation):如果多个事务同时并发执行,但每个事务就像各自独立执行一样。
4.持久性(Durability):一个事务执行成功,则对数据来说应该是一个明确的硬盘数据更改(而不仅仅是内存中的变化)。
1.3 语法
事务的开启:begin; start transaction;
事务的提交:commit;
事务的回滚:rollback;
1.4 示例
创建一个账户表模拟转账,并插入两行数据。
create table account (
id tinyint(5) zerofill auto_increment not null comment 'id编号',
name varchar(20) default null comment '客户姓名',
money decimal(10,2) not null comment '账户金额',
primary key (id)
)engine=innodb charset=utf8;
insert into account values ('1','张一','1000');
insert into account values ('1','张二','2000');
提交事务
mysql> begin;
Query OK, 0 rows affected (0.00 sec)
mysql> update account set money = money-500 where name = '张一';
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> update account set money = money+500 where name = '张二';
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> commit;
Query OK, 0 rows affected (0.00 sec)
2.视图
2.1 定义
视图(view)是一种虚拟存在的表,是一个逻辑表,它本身是不包含数据的。作为一个select语句保存在数据字典中的。
通过视图,可以展现基表(用来创建视图的表叫做基表base table)的部分数据,说白了视图的数据就是来自于基表
2.2 视图优缺点
视图的优点是:
1)简单:使用视图的用户完全不需要关心后面对应的表的结构、关联条件和筛选条件,对用户来说已经是过滤好的复合条件的结果集。
2)安全:使用视图的用户只能访问他们被允许查询的结果集,对表的权限管理并不能限制到某个行某个列,但是通过视图就可以简单的实现。
3)数据独立:一旦视图的结构确定了,可以屏蔽表结构变化对用户的影响,源表增加列对视图没有影响;源表修改列名,则可以通过修改视图来解决,不会造成对访问者的影响。
4)不占用空间:视图是逻辑上的表,不占用内存空间
总而言之,使用视图的大部分情况是为了保障数据安全性,提高查询效率。
缺点:
1)性能差:必须把视图查询转化成对基本表的查询,如果这个视图是由一个复杂的多表查询所定义,那么,即使是视图的一个简单查询,也要把它变成一个复杂的结合体,需要花费一定的时间。
2)修改限制:当用户试图修改试图的某些信息时,数据库必须把它转化为对基本表的某些信息的修改,对于简单的试图来说,这是很方便的,但是,对于比较复杂的试图,可能是不可修改的。
2.3 示例
mysql> create view employ as select empno,ename,job from employee;
Query OK, 0 rows affected (0.01 sec)
mysql> select * from employ;
+-------+--------+--------+
| empno | ename | job |
+-------+--------+--------+
| 1001 | 小乔 | 文员 |
| 1002 | 牛魔王 | 销售员 |
| 1003 | 程咬金 | 销售员 |
| 1004 | 猪八戒 | 经理 |
| 1005 | 后裔 | 销售员 |
| 1006 | 猴子 | 经理 |
| 1007 | 张飞 | 经理 |
| 1008 | 诸葛亮 | 分析师 |
| 1009 | 唐僧 | 董事长 |
| 1010 | 韩信 | 销售员 |
| 1011 | 妲己 | 文员 |
| 1012 | 安琪拉 | 文员 |
| 1013 | 林俊杰 | 分析师 |
| 1014 | 甄姬 | 文员 |
+-------+--------+--------+
14 rows in set (0.08 sec)
3.触发器
3.1 定义
触发器就是监视某种情况,并触发某种操作。
触发器的语法:
create trigger 触发器名称 after/before insert/update/delete on 表名
for each row
begin
sql语句;
end
3.2 演示
//创建一个员工迟到表:
create table work_time_delay(
empno int not null comment '雇员编号',
ename varchar(50) comment '雇员姓名',
status int comment '状态'
);
mysql> create trigger trig_work after insert on work_time_delay
-> for each row
-> begin
-> update employee set sal=sal-100 where empno=new.empno;
-> end;
4.存储过程
4.1 定义
存储过程就是把复杂的一系列操作,封装成一个过程。类似于shell,python脚本等。
优点是:复杂操作,调用简单,速度快。
缺点是:封装复杂,没有灵活性。
语法:
create procedure 名称 (参数....)
begin
过程体;
过程体;
end
声明变量:declare 变量名 类型(长度) default 默认值;
给变量赋值:set @变量名=值;
调用存储命令:call 名称(@变量名);
删除存储过程命令:drop procedure 名称;
查看创建的存储过程命令:show create procedure 名称\G;
4.2 示例
mysql> create procedure name(in n int)
-> begin
-> select * from employee limit n;
-> end;
Query OK, 0 rows affected (0.00 sec)
mysql> set @n=5;
->
Query OK, 0 rows affected (0.00 sec)
mysql>
mysql> call name(@n);