案例1:
#创建触发器:创建名称为before_insert的触发器,向test_trigger数据表插入数据之前,
#向test_trigger_log数据表中插入before_insert的日志信息。
CREATE TRIGGER before_insert
BEFORE INSERT ON test_trigger
FOR EACH ROW
INSERT INTO test_trigger_log(t_log) VALUES(‘beforeInsert’);
#插入数据到 test_trigger表中
INSERT INTO test_trigger(t_note) VALUES(‘test 2’);
#查询两个表的结果
SELECT * FROM test_trigger;
SELECT * FROM test_trigger_log;
查询结果:
#test_trigger表
±—±-------+
| id | t_note |
±—±-------+
| 1 | test 2 |
±—±-------+
#test_trigger_log表
±—±-------------+
| id | t_log |
±—±-------------+
| 1 | beforeInsert |
±—±-------------+
案例2:
#定义触发器“salary_check_trigger”,基于员工表“employees”的INSERT事件,
#在INSERT之前检查将要添加的新员工薪资是否大于他领导的薪资,
#如果大于领导薪资,则报sqlstate_value为’HY000’的错误,从而使得添加失败。
DELIMITER $
CREATE TRIGGER salary_check_trigger
BEFORE INSERT ON employees
FOR EACH ROW
BEGIN
#声明领导的工资
DECLARE mgr_sal DOUBLE;
#这个NEW可以理解为java中的当前对象,即把“NEW.manager_id”可以理解为:新员工的领导的员工号
SELECT salary INTO mgr_sal FROM employees WHERE employee_id = NEW.manager_id;
IF NEW.salary > mgr_sal
#这个也是一个知识点:“抛出”错误码‘HY000’,信息为:‘薪资高于领导薪资错误’
THEN SIGNAL SQLSTATE ‘HY000’ SET MESSAGE_TEXT = ‘薪资高于领导薪资错误’;
END IF;
END $
DELIMITER ;
DESC employees;
当添加新员工的工资不满足上述条件时,代码演示:
INSERT INTO employees
VALUES(301,‘A’,‘B’,‘C’,‘D’,‘2021-12-14’,‘F’,50000,NULL,205,110);
因为该新员工的领导(employee_id是205) 的工资是12000,所以:上述代码就会执行失败,报“错误代码:1644 薪资高于领导薪资错误”
的错误!!!
3、查看触发器
方式1:查看当前数据库的所有触发器的定义
SHOW TRIGGERS;
方式2:查看当前数据库中某个触发器的定义
SHOW CREATE TRIGGER 触发器名
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
最后
针对以上面试题,小编已经把面试题+答案整理好了
面试专题
除了以上面试题+答案,小编同时还整理了微服务相关的实战文档也可以分享给大家学习
专题
[外链图片转存中…(img-ak9caS4m-1711895235518)]
除了以上面试题+答案,小编同时还整理了微服务相关的实战文档也可以分享给大家学习
[外链图片转存中…(img-tvHRP65M-1711895235518)]
[外链图片转存中…(img-48AY6EZk-1711895235518)]
[外链图片转存中…(img-RO0YlFQ9-1711895235518)]