SQL中如何使用触发器,实现简单的触发功能?(二)

简介: 最近有小伙伴向我请求帮助,要写一个触发器。我看了一下需求很明确,就是执行更新,插入后触发一些事件。觉得挺有意思的,于是帮他写了一下,这里分享给大家。

需求代码

CREATETRIGGER T_出勤  --创建 触发器
ON 出勤
AFTERUPDATE,INSERT  
--一个触发器可以同时写更新插入和删除等动作
AS
BEGIN
--定义变量
DECLARE @IDINT;
DECLARE @出勤_上班时间 VARCHAR(20);
DECLARE @出勤_下班时间 VARCHAR(20);  
DECLARE @出勤_日期 INT;

--更新  出勤_上班时长
IF (UPDATE (出勤_上班时间) ORUPDATE (出勤_下班时间) )
--如果出勤_上班时间和出勤_下班时间发生了更新动作,则执行如下代码
BEGIN
--先获取更新后的值保留在变量中,其中inserted表为系统表,存放更新后的值
SELECT
@ID=ID,
@出勤_上班时间=出勤_上班时间,
@出勤_下班时间=出勤_下班时间
FROM inserted;
--将变量传入到表中,使取到的值唯一,对出勤_上班时长进行更新
UPDATE 出勤 SET 出勤_上班时长=
CONVERT(varchar(100) , DATEADD(ss, DATEDIFF(ss, 出勤_上班时间, 出勤_下班时间), 0), 108)
WHEREID=@ID
AND (出勤_上班时间=@出勤_上班时间
OR 出勤_下班时间=@出勤_下班时间);
END

--插入配置信息
IFUPDATE (出勤_日期)
--当出勤_日期发生了变动,我们执行如下更新。
BEGIN
--获取更新后的值传给变量
SELECT
@ID=ID ,
@出勤_日期=出勤_日期
FROM inserted;
--执行插入操作
INSERTINTO  配置(配置_日期,组_名,组类别_名,组_号,组类别_号)
SELECT
a.出勤_日期,b.组_名,c.组类别_名,a.组_号,c.组类别_号
FROM 出勤 a
JOIN 组 b ON a.组_号 = b.组_号
JOIN 组类别 c ON b.组类别_号 = c.组类别_号
WHERE a.ID=@ID
AND  a.出勤_日期=@出勤_日期  
END  
END


代码解读

1、触发器的语法这个必须掌握,本案例是在SQL Server下执行的,其他关系数据库的语法可能不同,请注意一下。

2、触发器中可以实现多种不同的操作,更新,删除,插入均可写在一个触发器上,当然要视情况而定

3、触发器在执行时会将更新前的数据存放在临时表deleted中,在更新后会将数据存放在临时表inserted中,这里我们就用到了临时表inserted

4、在更新上班时长时用到了时间处理函数DATEDIFF和DATEADD,两个函数是比较常用的时间处理函数,必须掌握。

5、参数传递是代码中比较重要一环,我们是先将临时表中的数据存放在一个变量中保存,在我们真正进行更新或插入操作时候再把这个变量取出来使用,就是将变量再次传递给条件语句。


测试功能

1、在测试数据之前,我们先看看出勤表和配置表中的数据

出勤

45.jpg


我们看到出勤_上班时长是没有数据的,下面我们开始更新

UPDATE 出勤 SET 出勤_上班时间='7:00'
WHEREID=1

执行完后我们再看出勤表中的数据是否有变化

46.jpg

从上图可以看出,结果符合我们预期,同理更新下班时间也会对上班时长进行更新操作,这里就不演示了。

2、我们插入数据是否也会更新上班时长呢?我们执行如下语句

INSERTINTO 出勤(出勤_月份,出勤_日期,
出勤_上班时间,出勤_下班时间,组_号)
VALUES (12,11,'8:30','12:00','01')

执行完后我们查看一下结果

47.jpg


结果也符合我们的预期。


3、当出勤表中的日期被更新的时候,配置表里是否会插入了一条数据?我们先看看配置表中的数据

48.jpg

我们对出勤表中的日期进行更新操作,看配置表会不会多一条记录?

UPDATE dbo.出勤 SET 出勤_日期='22'
WHEREID=2

更新后我们看看配置表中的数据


49.jpg

结果也符合我们的预期。


总结

整个案例其实精华部分就只是触发器部分,但是为了让小伙伴们能更加清晰的阅读和思考,故将整个案例从需求到测试都给大家展现出来。而触发器部分如果对其语法比较了解,使用起来并没有想象的那么难。当然其中有一些小技巧还是需要大家去了解一下,就比如将更新和插入操作写在一个触发器是可以的。我们也可以指定只有哪几列发生更新操作的时候才执行相应的语句。最后,如果你有一些比较经典的需求,也可以发送给我,兴许下次展示的就是你的案例啦!

相关文章
|
3月前
|
SQL
SQL如何在CTE中使用Order By的功能
SQL Server如何在CTE中使用Order By的功能
|
7月前
|
SQL Java 数据库连接
【YashanDB知识库】statement级别的触发器在jdbc接口调用executeBatch时被多次触发
statement级别的触发器在jdbc接口调用executeBatch时被多次触发
|
7月前
|
SQL 分布式计算 资源调度
Dataphin功能Tips系列(48)-如何根据Hive SQL/Spark SQL的任务优先级指定YARN资源队列
如何根据Hive SQL/Spark SQL的任务优先级指定YARN资源队列
215 4
|
12月前
|
SQL 数据库 开发者
ClkLog埋点分析系统支持自定义SQL 查询
本期主要为大家介绍ClkLog九月上线的新功能-自定义SQL查询。
ClkLog埋点分析系统支持自定义SQL 查询
|
11月前
|
SQL 关系型数据库 MySQL
SQL中,可以使用 `ORDER BY` 子句来实现排序功能
【10月更文挑战第26天】SQL中,可以使用 `ORDER BY` 子句来实现排序功能
912 6
|
11月前
|
SQL 关系型数据库 MySQL
MySql5.6版本开启慢SQL功能-本次采用永久生效方式
MySql5.6版本开启慢SQL功能-本次采用永久生效方式
139 0
|
SQL 运维 程序员
一个功能丰富的SQL审核查询平台
一个功能丰富的SQL审核查询平台
189 2
|
SQL 流计算
Flink SQL 在快手实践问题之Window TVF改进窗口聚合功能如何解决
Flink SQL 在快手实践问题之Window TVF改进窗口聚合功能如何解决
156 1
|
SQL 存储 OLAP
OneSQL OLAP实践问题之Flink SQL Gateway的功能如何解决
OneSQL OLAP实践问题之Flink SQL Gateway的功能如何解决
148 1
解锁 SQL Server 2022的时间序列数据功能
【7月更文挑战第14天】要解锁SQL Server 2022的时间序列数据功能,可使用`generate_series`函数生成整数序列,例如:`SELECT value FROM generate_series(1, 10)。此外,`date_bucket`函数能按指定间隔(如周)对日期时间值分组,这些工具结合窗口函数和其他时间日期函数,能高效处理和分析时间序列数据。更多信息请参考官方文档和技术资料。
279 9

热门文章

最新文章