MySQL触发器的创建、查看、删除、存储过程与触发器的区别等
2024-01-02 10:50:19
1、什么是触发器
简单点来说触发器就是一个特殊的存储过程,不过存储过程需要手动调用,而触发器自动调用。
一张图来简单说明触发器:
触发器:触发器是数据库中针对数据库表操作触发的一种特殊的存储过程。
2、创建触发器
delimiter $$
create trigger 数据库名.触发器名
before/after -- 触发器执行的顺序
insert/update/delete -- 触发事件
on 数据库名.表名 -- 事件表
for each row
begin
触发器内容 -- 事件触发后要写的语句
end $$
delimiter ;
说明:
触发器触发时间分为before和after两种
主要针对表的增删改操作,可单独指定,也可全部指定。
eg:
delimiter $$
create trigger trig_delstu_delsc
before delete on student for each row
begin
-- old 已经存在于数据库中的数据
-- new 还不存在于数据库中的数据
delete from sc where sid = old.sid;
end $$
delimiter ;
3、查看所有的触发器
SELECT * FROM information_schema.`TRIGGERS`
WHERE trigger_schema = ‘库名'
4、删除触发器
DROP TRIGGER 触发器名
5、常见的触发器案例
利用触发器映射部门表中每个部门的总人数和平均工资,步骤:
? 1、创建部门表,包含字段部门编号,部门名称,部门人数和平均工资;
? 2、创建触发器;
? 3、分别执行DML语句验证。
利用触发器记录删除的数据,并保存在删除表中,步骤:
? 1、创建删除记录表;
? 2、创建触发器;
? 3、执行DELETE语句验证。
6、存储过程与触发器的区别
- 语法:存储过程procedure,触发器trigger
- 执行:存储过程需要调用菜执行,触发器自动执行
- 返回值:存储过程可以定义返回值,触发器没有返回值
- 功能:存储过程是一组特定功能的SQL语句,触发器则是SQL语句前后执行,本身不影响原功能。
文章来源:https://blog.csdn.net/LIJINGPO/article/details/135315867
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!