17章MySQL:触发器

文章介绍了在Java中创建数据库触发器的实战案例,以及如何使用触发器进行数据验证。同时,提到了高级Java面试技巧和常用技术知识点总结,包括消息队列、Redis缓存等,为开发者提供学习资源和职业发展指导。
摘要由CSDN通过智能技术生成

id INT PRIMARY KEY AUTO_INCREMENT,

t_note VARCHAR(30)

);

CREATE TABLE test_trigger_log (

id INT PRIMARY KEY AUTO_INCREMENT,

t_log VARCHAR(30)

);

案例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;

当添加新员工的工资不满足上述条件时,代码演示:

先自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《Java开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频

如果你觉得这些内容对你有帮助,可以扫码领取!

img

2021年Java中高级面试必备知识点总结

在这个部分总结了2019年到目前为止Java常见面试问题,取其面试核心编写成这份文档笔记,从中分析面试官的心理,摸清面试官的“套路”,可以说搞定90%以上的Java中高级面试没一点难度。

本节总结的内容涵盖了:消息队列、Redis缓存、分库分表、读写分离、设计高并发系统、分布式系统、高可用系统、SpringCloud微服务架构等一系列互联网主流高级技术的知识点。

目录:

(上述只是一个整体目录大纲,每个点里面都有如下所示的详细内容,从面试问题——分析面试官心理——剖析面试题——完美解答的一个过程)

部分内容:

对于每一个做技术的来说,学习是不能停止的,小编把2019年到目前为止Java的核心知识提炼出来了,无论你现在是处于什么阶段,如你所见,这份文档的内容无论是对于你找面试工作还是提升技术广度深度都是完美的。

不想被后浪淘汰的话,赶紧搞起来吧,高清完整版一共是888页,需要的话可以点赞+关注
链图片转存中…(img-JePMl1B7-1711349348553)]

对于每一个做技术的来说,学习是不能停止的,小编把2019年到目前为止Java的核心知识提炼出来了,无论你现在是处于什么阶段,如你所见,这份文档的内容无论是对于你找面试工作还是提升技术广度深度都是完美的。

不想被后浪淘汰的话,赶紧搞起来吧,高清完整版一共是888页,需要的话可以点赞+关注
需要更多Java资料的小伙伴可以帮忙点赞+关注,点击传送门,即可免费领取!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值