一篇文章带你深入了解Mysql触发器


Posted in MySQL onAugust 02, 2021

基于school数据库中的student, course, sc表,创建满足下述要求的触发器:

数据库navicat cmd界面运行

1.对SC表进行插入或修改时,如果考试成绩不在0-100范围内时,则撤销插入或修改操作。

DELIMITER ;
DROP TRIGGER IF EXISTS `tri_update_grade`;
DELIMITER ;;
CREATE TRIGGER `tri_update_grade` BEFORE UPDATE ON `sc` FOR EACH ROW begin
if new.grade > 100 then
delete from sc;
elseif new.grade < 0 then
delete from sc;
end if;
end
;;
DELIMITER ;
DROP TRIGGER IF EXISTS `tri_insert_grade`;
DELIMITER ;;
CREATE TRIGGER `tri_insert_grade` BEFORE INSERT ON `sc` FOR EACH ROW begin
if new.grade > 100 then
delete from sc;
elseif new.grade < 0 then
delete from sc;
end if;
end
;;

2.对SC表进行插入时,如果学生的选课总学分超过30,则报错并撤销插入。

DELIMITER ;
DROP TRIGGER IF EXISTS `tri_insert_credit`;
DELIMITER ;;
CREATE TRIGGER `tri_insert_credit` BEFORE INSERT ON `sc` FOR EACH ROW begin
SELECT sum(Ccredit) INTO @sumcred from Student join SC on SC.Sno=Student.Sno join Course on Course.Cno=SC.Cno WHERE sc.Sno=new.Sno;
if (@sumcred>30)
then
delete from sc;
end if;
end
;;

3.对SC表进行修改时,不允许修改考试成绩不及格的学生选课记录。

DELIMITER ;
DROP TRIGGER IF EXISTS `tri_grade`;
DELIMITER ;;
CREATE TRIGGER `tri_grade` BEFORE UPDATE ON `sc` FOR EACH ROW begin
select grade INTO @gra from sc where sno=new.sno and sno=new.sno;
if (@gra >= 60)
then
set new.grade=20;
else
delete from sc;
end if;
end
;;

4.对STUDENT表进行插入时,如果年龄为空,则将该生年龄设置为所有学生年龄的平均值。

DELIMITER ;
DROP TRIGGER IF EXISTS `tri_student`;
DELIMITER ;;
CREATE TRIGGER `tri_student` BEFORE INSERT ON `student` FOR EACH ROW begin
select avg(Sage) INTO @avgage from student;
SET @old_age = new.Sage;
if @old_age IS NULL
then
set new.Sage=@avgage;
end if;
end
;;

5.在STUDENT表中增加两列,分别用来存放学生的平均成绩和等级,并对SC表进行插入后,自动维护学生的平均成绩和等级(85-100,等级为“优"; 60-85,等级为“良”,60 以下,等级为“差")

DELIMITER ;
DROP TRIGGER IF EXISTS `tri_comment`;
DELIMITER ;;
CREATE TRIGGER `tri_comment` BEFORE UPDATE ON `student` FOR EACH ROW begin
select avg(Grade) INTO @avggra from sc where sno=new.sno;
if @avggra > 85 then
update sc set new.Savg=@avggra,new.Scomment="you";
else if @avggra > 60 and @avggra <= 85 then
update sc set new.Savg=@avggra,new.Scomment="you";
else
update sc set new.Savg=@avggra,new.Scomment='cha';
end if;
end if;
end
;;
DELIMITER ;

总结

本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注三水点靠木的更多内容!

MySQL 相关文章推荐
MySQL的join buffer原理
Apr 29 MySQL
分析MySQL抛出异常的几种常见解决方式
May 18 MySQL
MySQL 全文检索的使用示例
Jun 07 MySQL
mysql备份策略的实现(全量备份+增量备份)
Jul 07 MySQL
mysql脏页是什么
Jul 26 MySQL
mysql事务对效率的影响分析总结
Oct 24 MySQL
如何避免mysql启动时错误及sock文件作用分析
Jan 22 MySQL
Mysql Innodb存储引擎之索引与算法
Feb 15 MySQL
MySQL优化及索引解析
Mar 17 MySQL
利用JuiceFS使MySQL 备份验证性能提升 10 倍
Mar 17 MySQL
进阶篇之linux环境下安装MySQL数据库
Apr 09 MySQL
Mysql中的触发器定义及语法介绍
Jun 25 MySQL
sql注入教程之类型以及提交注入
MySQL子查询中order by不生效问题的解决方法
Aug 02 #MySQL
MySQL中utf8mb4排序规则示例
Aug 02 #MySQL
MySql子查询IN的执行和优化的实现
MySQL里面的子查询的基本使用
Aug 02 #MySQL
Centos7中MySQL数据库使用mysqldump进行每日自动备份的编写
Aug 02 #MySQL
为什么MySQL选择Repeatable Read作为默认隔离级别
You might like
中国的第一台收音机
2021/03/01 无线电
个人写的PHP验证码生成类分享
2014/08/21 PHP
PHP实现搜索相似图片
2015/09/22 PHP
详解PHP的Yii框架中扩展的安装与使用
2016/04/01 PHP
PHP 5.6.11 访问SQL Server2008R2的几种情况详解
2016/08/08 PHP
php 文件下载 出现下载文件内容乱码损坏的解决方法(推荐)
2016/11/16 PHP
Thinkphp框架中D方法与M方法的区别
2016/12/23 PHP
PHP+jQuery实现即点即改功能示例
2019/02/21 PHP
php+Ajax无刷新验证用户名操作实例详解
2019/03/04 PHP
window.addeventjs事件驱动函数集合addEvent等
2008/02/19 Javascript
JavaScript的9个陷阱及评点分析
2008/05/16 Javascript
JS在textarea光标处插入文本的小例子
2013/03/22 Javascript
深入理解javascript作用域和闭包
2014/09/23 Javascript
纯js代码实现简单计算器
2015/12/02 Javascript
jquery自定义右键菜单、全选、不连续选择
2016/03/01 Javascript
AngularJs Dependency Injection(DI,依赖注入)
2016/09/02 Javascript
微信小程序 后台https域名绑定和免费的https证书申请详解
2016/11/10 Javascript
vue中render函数的使用详解
2018/10/12 Javascript
详解如何使用微信小程序云函数发送短信验证码
2019/03/13 Javascript
jQuery擦除插件eraser使用方法详解
2020/01/11 jQuery
JavaScript如何实现防止重复的网络请求的示例
2021/01/28 Javascript
Cython 三分钟入门教程
2009/09/17 Python
Python Web框架Flask中使用七牛云存储实例
2015/02/08 Python
利用Python实现微信找房机器人实例教程
2019/03/10 Python
移动Web—CSS为Retina屏幕替换更高质量的图片
2012/12/24 HTML / CSS
APM Monaco中国官网:来自摩纳哥珠宝品牌
2017/12/27 全球购物
实习生自荐信范文
2013/11/13 职场文书
2014自主招生自荐信策略
2014/01/27 职场文书
五一促销活动总结
2014/07/01 职场文书
2014预备党员批评与自我批评思想汇报
2014/09/20 职场文书
法定代表人授权委托书范本
2014/10/07 职场文书
大学生入党积极分子党校学习思想汇报
2014/10/25 职场文书
办公室文员岗位职责
2015/02/04 职场文书
教学质量月活动总结
2015/05/11 职场文书
大学军训通讯稿
2015/07/18 职场文书
导游词之无锡梅园
2019/11/28 职场文书