一、事务
MySQL中如果一张表需要使用事务,需要设置表的引擎为innodb引擎
1、事务的基本操作
-- 事务的开启:
begin;
start transaction;
-- 事务的提交:(提交之前,数据仅仅会在内存中保存,不会造成硬盘数据的修改)
commit;
-- 事务的回滚:
rollback;
一般的sql(非事务)为什么一行下去就可以直接生效(影响到硬盘数据)呢?
因为有这个设置。autocommit=1
相当于我们每一个sql执行的时候,数据库会默认帮我们加一个commit;命令,自动提交
如果自动提交的设置关闭,我们再进行操作的时候,只会影响内存,不会影响硬盘。
2、开启autocommit(临时生效):
-- 普通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 |
3、开启autocommit(永久生效):
-- 修改配置文件:
vi /etc/my.cnf
-- 在[mysqld]下面加上:
autocommit=1
-- 记得重启服务才会生效
二、视图
1、 什么是视图
2、视图的优点
3、视图的创建以及修改
-- 创建的基本语法是:
create view <视图名称> as select 语句;
create view <视图名称> (字段) as select 语句;
create or replace view <视图名称>; --如果存在就替换
修改的语法是:
alter view <视图名称> as select 语句;
视图删除语法:
drop view <视图名称> ;
- 视图的缺点
三、触发器
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:它们可以在执行insert、update或delete的过程中触发
for each row:每隔一行执行一次动作
4、删除触发器
drop trigger 触发器名称;
- 演示
创建一个员工迟到表:
create table work_time_delay(
empno int not null comment '雇员编号',
ename varchar(50) comment '雇员姓名',
status int comment '状态'
);
-- 小知识点:自定义的结束符号 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();