目录

事务的开启与提交:

开启autocommit(临时生效):

开启autocommit(永久生效):

视图的应用

视图的创建以及修改

触发器

Mysql的存储过程


什么是事务?
数据库事务通常指对数据库进行读或写的一个操作过程。

有两个目的,第一个是为数据库操作提供了一个从失败中恢复到正常状态的方法,同时提供了数据库即使在异常状态下仍能保持一致性的方法;

第二个是当多个应用程序在并发访问数据库时,可以在这些应用程序之间提供一个隔离方法,以防止彼此的操作互相干扰。
 

原子性(Atomicity):事务必须是原子工作单元,一个事务中的所有语句,应该做到:要么全做,要么一个都不做;
一致性(Consistency):让数据保持逻辑上的“合理性”,比如:小明给小红打10000块钱,既要让小明的账户减少10000,又要让小红的账户上增加10000块钱;
隔离性(Isolation):如果多个事务同时并发执行,但每个事务就像各自独立执行一样。
持久性(Durability):一个事务执行成功,则对数据来说应该是一个明确的硬盘数据更改(而不仅仅是内存中的变化)。

你要使用事务的话,表的引擎要为innodb引擎
 


事务的开启与提交:

事务的开启:begin; (5.7)start transaction;(旧版本)
事务的提交:commit;
事务的回滚:rollback;
 

创建一个账户表模拟转账

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;

1、开启事务

2、创建表,并使用innodb引擎、在表中插入数据

mysql事物管理机制 mysql是如何管理事务的_mysql事物管理机制

mysql事物管理机制 mysql是如何管理事务的_数据_02

此时只保存到内存并没有提交到磁盘(持久性)

在没有提交之前,从另一个客户端查看表是看不到该表插入的数据的

 

删除数据表之后,如果不提交其他的客户端仍然能够访问到删除的数据,隔离性

mysql事物管理机制 mysql是如何管理事务的_触发器_03

一般的自动提交开启了。

mysql事物管理机制 mysql是如何管理事务的_数据_04

 

开启autocommit(临时生效):

OFF(0):表示关闭

ON (1):表示开启
 

mysql> set autocommit=0;
 Query OK, 0 rows affected (0.00 sec)
  mysql> show variables like 'autocommit';
 +---------------+-------+
 | Variable_name | Value |
 +---------------+-------+
 | autocommit | OFF |
 +---------------+-------+
 mysql> set autocommit=1;
 Query OK, 0 rows affected (0.00 sec)

 mysql> show variables like 'autocommit';
 +---------------+-------+
 | Variable_name | Value |
 +---------------+-------+
 | autocommit | ON |


 

开启autocommit(永久生效):

修改配置文件:vi /etc/my.cnf 在[mysqld]下面加上:autocommit=1 记得重启服务才会生效

 

查看支持的引擎方法:

只有InnoDB支持事务

mysql事物管理机制 mysql是如何管理事务的_mysql_05


mysql事物管理机制 mysql是如何管理事务的_mysql_06


mybits整合事务

一般在service层

1、service逻辑引入事务 @Transantional(propagation=Propagation.REQUIRED)
2、service代码
	@Override
    @Transactional
	public int addAccount() {
		User user = new User();
		user.setAge(9);
		user.setCreateTime(new Date());
		user.setName("事务测试");
		user.setPhone("000121212");
		
		userMapper.insert(user);
        int a = 1/0;

		return user.getId();
	}

 

 

 

 


视图的应用

什么是视图?视图的作用是什么?
 

视图(view)是一种虚拟存在的表,是一个逻辑表,它本身是不包含数据的。作为一个select语句保存在数据字典中的。
通过视图,可以展现基表(用来创建视图的表叫做基表base table)的部分数据,说白了视图的数据就是来自于基表
(可以屏蔽某些数据,只看想要的数据)

优点:

1)简单:使用视图的用户完全不需要关心后面对应的表的结构、关联条件和筛选条件,对用户来说已经是过滤好的复合条件
的结果集。
2)安全:使用视图的用户只能访问他们被允许查询的结果集,对表的权限管理并不能限制到某个行某个列,但是通过视图就
可以简单的实现。

例如:支付宝在交给第三方开发的时候,不可能将用户的全部信息都交给第三方公司,将部分数据通过视图的形式提交。

3)数据独立:一旦视图的结构确定了,可以屏蔽表结构变化对用户的影响,源表增加列对视图没有影响;

                          源表修改列名,则可以通过修改视图来解决,不会造成对访问者的影响。
4)不占用空间:视图是逻辑上的表,不占用内存空间

总而言之,使用视图的大部分情况是为了保障数据安全性,提高查询效率。
 

视图的创建以及修改
 

创建语法:

create view <视图名称> as select 语句;
create view <视图名称> (字段) as select 语句;
create or replace view <视图名称>;
 

mysql事物管理机制 mysql是如何管理事务的_mysql事物管理机制_07

例如:财务只能知道编号empno和sal员工的其他信息不能知道,

           员工只能知道员工姓名,sal薪水不能知道

   通过视图就能够简单的实现上面的要求。

mysql事物管理机制 mysql是如何管理事务的_mysql_08

mysql事物管理机制 mysql是如何管理事务的_触发器_09

mysql事物管理机制 mysql是如何管理事务的_mysql事物管理机制_10

当成表来用。

mysql事物管理机制 mysql是如何管理事务的_触发器_11

修改基表中的数据,视图中的数据也会跟着修改。

 

修改的语法是:
alter view <视图名称> as select 语句;
 

视图删除语法:
drop view <视图名称> ;
 

缺点:

1)性能差:sql server必须把视图查询转化成对基本表的查询,如果这个视图是由一个复杂的多表查询所定义,那么,即
使是视图的一个简单查询,sql server也要把它变成一个复杂的结合体,需要花费一定的时间。
2)修改限制:当用户试图修改试图的某些信息时,数据库必须把它转化为对基本表的某些信息的修改,对于简单的试图来
说,这是很方便的,但是,对于比较复杂的试图,可能是不可修改的。
 


触发器

什么是?

 

 

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

使用的不多,大量数据的时候性能不好(对每一条都要处理)

创建触发器的语法:

create trigger 触发器名称 after/before insert/update/delete on 表名
                  for each row
                  begin
                  sql语句;
                  end

after/before:可以设置为事件发生前或后

insert/update/delete:它们可以在执行insert、update或delete的过程中触发

for each row:每隔一行执行一次动作

mysql事物管理机制 mysql是如何管理事务的_触发器_12

删除触发器的语法:
drop trigger 触发器名称;
 

创建一个员工迟到表:

create table work_time_delay(
          empno int not null comment '雇员编号',
          ename varchar(50) comment '雇员姓名',
          status int comment '状态'
 );delimiter // 自定义语句的结束符号(将;改为//)
 mysql> delimiter //

 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
 -> //
 Query OK, 0 rows affected (0.01 sec)
 new:指的是事件发生before或者after保存的新数据


 


Mysql的存储过程

什么是?

存储过程就是把复杂的一系列操作,封装成一个过程。类似于shell,python脚本等

几乎不用,用了的话分库分表基本就没有用了。

 

优点是:
1)复杂操作,调用简单
2)速度快
缺点是:
1)封装复杂
2) 没有灵活性
 

create procedure 名称 (参数....)

      begin

      过程体;

      过程体;

      end

mysql事物管理机制 mysql是如何管理事务的_mysql_13

mysql事物管理机制 mysql是如何管理事务的_mysql_14

mysql事物管理机制 mysql是如何管理事务的_数据_15

无参数的自定义的

mysql事物管理机制 mysql是如何管理事务的_数据_16

查询n(5条)数据

参数:in|out|inout 参数名称 类型(长度)
in:表示调用者向过程传入值(传入值可以是字面量或变量)
out:表示过程向调用者传出值(可以返回多个值)(传出值只能是变量)
inout:既表示调用者向过程传入值,又表示过程向调用者传出值(值只能是变量)
 

声明变量:declare 变量名 类型(长度) default 默认值;
给变量赋值:set @变量名=值;
调用存储命令:call 名称(@变量名);
删除存储过程命令:drop procedure 名称;
查看创建的存储过程命令:
 

show create procedure 名称\G;
 

创建一个简单的存储过程:

mysql> delimiter //
 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);
  mysql> create procedure name()
 -> begin
 -> declare n int default 6;
 -> select * from employee limit n;
 -> end
 -> //
 Query OK, 0 rows affected (0.00 sec)
 mysql> call name();