MySQL学习笔记(四) —— 事务、视图、触发器&存储过程

事务、视图、触发器&存储过程

    • 一、事务
      • 1、事务的基本操作
      • 2、开启autocommit(临时生效):
      • 3、开启autocommit(永久生效):
    • 二、视图
      • 1、 什么是视图
      • 2、视图的优点
      • 3、视图的创建以及修改
    • 三、触发器
      • 1、什么是触发器?
      • 2、查看触发器信息
      • 3、创建触发器
      • 4、删除触发器
    • 四、存储过程
      • 1、什么是存储过程
      • 2、存储过程的优缺点
      • 3、创建存储过程
      • 4、案例

一、事务

事务的特性

  1. 原子性(Atomicity):事务必须是原子工作单元,一个事务中的所有语句,要么全做,要么一个都不做。
  2. 一致性(Consistency):让数据保持逻辑上的“合理性”,A给B转账,必须A少钱,B加钱
  3. 隔离性(Isolation):如果多个事务同时并发执行,每个事务都是独立的
  4. 持久性(Durability):一个事务执行成功,对于数据来说是一个硬盘的数据更改(不只是内存层面)

MySQL中如果一张表需要使用事务,需要设置表的引擎为innodb引擎

1、事务的基本操作

-- 事务的开启:
begin;
start transaction;
-- 事务的提交:(提交之前,数据仅仅会在内存中保存,不会造成硬盘数据的修改)
commit;
-- 事务的回滚:
rollback;

一般的sql(非事务)为什么一行下去就可以直接生效(影响到硬盘数据)呢?
因为有这个设置。autocommit=1
相当于我们每一个sql执行的时候,数据库会默认帮我们加一个commit;命令,自动提交

如果自动提交的设置关闭,我们再进行操作的时候,只会影响内存,不会影响硬盘。


2、开启autocommit(临时生效):

OFF(0):表示关闭
ON (1):表示开启

-- 普通sql即时更新
show variables like 'autocommit';

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    |

MySQL学习笔记(四) —— 事务、视图、触发器&存储过程_第1张图片

3、开启autocommit(永久生效):

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

二、视图

1、 什么是视图

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

2、视图的优点

  • 简单:使用视图的用户完全不需要关心后面对应的表的结构、关联条件和筛选条件,对用户来说已经是过滤好的复合条件的结果集。
  • 安全:使用视图的用户只能访问他们被允许查询的结果集,对表的权限管理并不能限制到某个行某个列,但是通过视图就可以简单的实现。
  • 数据独立:一旦视图的结构确定了,可以屏蔽表结构变化对用户的影响,源表增加列对视图没有影响;源表修改列名,则可以通过修改视图来解决,不会造成对访问者的影响。
  • 不占用空间:视图是逻辑上的表,不占用内存空间 总而言之,使用视图的大部分情况是为了保障数据安全性,提高查询效率。

3、视图的创建以及修改

-- 创建的基本语法是:
create view <视图名称> as select 语句;
create view <视图名称> (字段) as select 语句;
create or replace view <视图名称>; --如果存在就替换
修改的语法是:
alter view <视图名称> as select 语句;
视图删除语法:
drop view <视图名称> ;
  • 视图的缺点
  • 性能差:sql必须把视图查询转化成对基本表的查询,如果这个视图是由一个复杂的多表查询所定义,那么,即使是视图的一个简单查询,sql也要把它变成一个复杂的结合体,需要花费一定的时间。
  • 修改限制:当用户试图修改视图的某些信息时,数据库必须把它转化为对基本表的某些信息的修改,对于简单的试图来说,这是很方便的,但是,对于比较复杂的视图,可能是不可修改的。如关联外键等等。

三、触发器

1、什么是触发器?

触发器就是监视某种情况发生时,触发另一个操作

2、查看触发器信息

show create trigger 触发器名称\G 
-- \G可以格式化输出 

3、创建触发器

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

-- 解释
after/before:可以设置为事件发生前或后
insert/update/delete:它们可以在执行insertupdatedelete的过程中触发
for each row:每隔一行执行一次动作

4、删除触发器

drop trigger 触发器名称;
  • 演示
创建一个员工迟到表:
 create table work_time_delay(
            empno int not null comment '雇员编号',
            ename varchar(50) comment '雇员姓名',
            status int comment '状态'
            );

MySQL学习笔记(四) —— 事务、视图、触发器&存储过程_第2张图片

-- 小知识点:自定义的结束符号 delimiter
-- 将每一个sql的结束符号换成//
delimiter // 自定义语句的结束符号

-- 将每一个sql的结束符号换成//
mysql> delimiter //

-- 创建一个触发器
-- 当检测到work_time_delay表中有insert操作的时候,就执行14行更新操作
-- 14行程序where后,new 是指work_time_delay表中新数据,new.empno指新数据的列信息
mysql> create trigger trig_work after insert on work_time_delay
    -> for each row
    -> begin
    -> update employee set sal=sal-100 where employee.empno=new.empno;
    -> end
    -> //
Query OK, 0 rows affected (0.01 sec)

new:指的是事件发生before或者after保存的新数据

四、存储过程

1、什么是存储过程

就是相当于把复杂的操作封装成一个“过程”。类似于写了一个功能函数。

2、存储过程的优缺点

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

3、创建存储过程

create procedure 名称 (参数....)
        begin
         过程体;
         过程体;
         end
         
参数:in|out|inout 参数名称 类型(长度)
        in:表示调用者向过程传入值(传入值可以是字面量或变量)
        out:表示过程向调用者传出值(可以返回多个值)(传出值只能是变量)
        inout:既表示调用者向过程传入值,又表示过程向调用者传出值(值只能是变量)
        
声明变量:declare 变量名 类型(长度) default 默认值;
给变量赋值:set @变量名=;
  • 调用存储过程命令
call 名称(@变量名);
  • 删除存储过程命令
drop procedure 名称;
  • 查看存储过程信息
show create procedure 名称\G;

4、案例

-- 创建一个存储过程
create procedure  name(in n int)
    begin
    select * from employee limit n;
    end
-- 设置一个变量
set @n=5
-- 调用名字为name的存储过程
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();

你可能感兴趣的:(#,MySQL,mysql,数据库,sql)