【MySQL数据库】九、触发器,存储过程

一、触发器

SQL语句结束符可以进行修改:

delimiter 语句结束符;//修改
delimiter $$;//将SQL语句结束符修改为$$

表示将语句结束符修改为$$,不用使用;进行结尾。记得使用完毕后修改回来。

创建一个变量

set @tmp=10;//创建一个变量初始化为10

(一)基本概念

触发器:触发器是与表相关的数据库对象,当一个事件(操作)到来时,触发器触发,去执行另外一系列操作。不需要手动启动,只要当一个预定义事件发生时,就会被MySQL自动调用触发器也是一个结构,使用DDL语句操作。

【1. 触发器的类型:】

触发器类型 触发事件
insert型触发器 insert,load data,replace
update型触发器 update
delete型触发器 delete,replace

load data表示将一个文件加载到一个数据表中,类似insert操作。

【2. 触发器被触发的时间】

触发时间 含义
before 事件到来之前触发
after 事件到来之后触发

那么一共有2*3=6种触发器类型,一张表,同类型的触发器最多存在一个,所以一张表最多6个触发器。

【3. 查看触发器:】

查看数据库中已存在的触发器的定义,状态语法信息等:

show triggers;

【4. 删除触发器:】

删除MySQL库中已经定义的触发器:

drop trigger 库名.触发器名称;
如:
drop trigger Review.tri_1;//删除Review库上的触发器

(二)创建触发器

创建触发器的四要素:

  • 触发器依赖的表
  • 触发器类型和触发事件类型
  • 触发时间
  • 触发后执行地SQL语句
create trigger tri_name
tri_time #before,after触发时间
tri_event #触发器类型和事件:insert,delete,update
on tablename #表名
for each row
begin
tri_stmt; #触发后执行地操作
end
$$ #结束符

【例子:创建插入型触发器】

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值