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

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

任务需求

有如下四张表:

出勤

40.jpg


41.jpg

组类别


42.jpg

配置

43.jpg

1.更新[出勤_上班时长] 如果:"出勤"表,[出勤_上班时间]或者[出勤_下班时间],列发生改变所触发事件

  • 更新上述两列 "出勤"表,出勤_上班时长 = 出勤_下班时间 - 出勤_上班时间
  • 插入上述两列 "出勤"表,出勤_上班时长不插数据,插入完成后计算它。出勤_上班时长 = 出勤_下班时间 - 出勤_上班时间  


2.插入 如果:"出勤"表,[出勤_日期],列发生改变所触发事件

插入 (配置_日期,组_名,组类别_名,组_号,组类别_号)

查询[a.出勤_日期,b.组_名,c.组类别_名,a.组_号,c.组类别_号]


创建表结构

根据给定的表结构,我们创建到数据库中

/*
时间:2018-12-26
作者:Lyven
需求:创建一个触发器,完成相应的更新和插入功能
*/

Use SQL_Road
CREATETABLE 出勤
(IDINTIDENTITY(1,1) NOTNULL PRIMARY KEY,
出勤_月份 INT ,
出勤_日期 INT ,
出勤_上班时间 VARCHAR(20),
出勤_下班时间 VARCHAR(20),
出勤_上班时长 VARCHAR(20),
组_号 VARCHAR(10)
)

CREATETABLE
(IDINTIDENTITY(1,1) NOTNULL PRIMARY KEY,
组_号 VARCHAR(10),
组_名 NVARCHAR(20),
组类别_号 VARCHAR(10),
组_人数 INT
)

CREATETABLE 组类别
(IDINTIDENTITY(1,1) NOTNULL PRIMARY KEY,
组类别_号 VARCHAR(10),
组类别_名 NVARCHAR(20),
组类别_时薪 NUMERIC(18,2)
)

CREATETABLE 配置
(IDINTIDENTITY(1,1) NOTNULL PRIMARY KEY,
配置_日期 INT,
组_名 VARCHAR(20),
组类别_名 NVARCHAR(20),
配置_工时 VARCHAR(20),
配置_工资 NUMERIC(18,2),
组_号 VARCHAR(10),
组类别_号 VARCHAR(10)
)
GO


插入测试数据

INSERTINTO 出勤(出勤_月份,出勤_日期,出勤_上班时间,出勤_下班时间,组_号)
VALUES
( 1, 12, 24, '7:30', '12:35', '01' ),
( 2, 12, 25, '8:00', '12:28', '01' ),
( 3, 12, 26, '8:30', '12:00', '01' )

INSERTINTO 组(组_号,组_名,组类别_号,组_人数)
VALUES
( '01', 'CAD', '01', 2 ),
( '02', 'MAX', '02', 1 ),
( '03', 'U3D', '03', 3 )

INSERTINTO 组类别(组类别_号,组类别_名,组类别_时薪)
VALUES
( '01', N'自动', 100.00 ),
( '02', N'员工', 200.00 ),
( '03', N'学员', 150.00 )

INSERTINTO 配置(配置_日期 , 组_名, 组类别_名, 配置_工资 ,
组_号, 组类别_号)
VALUES
( 24, 'CAD', N'自动', 12.50, '01', '01' ),
( 25, 'MAX', N'员工', 12.60, '02', '02' ),
( 26, 'U3D', N'学员', 12.70, '03', '03' )


分析需求

  1. 第一个需求其实是只要上班时间和下班时间,我们就自动给它算出这个时长,其实这样的需求在插入的时候就可以解决,这里我们不讨论这种优化方案,只是根据这个需求看该如何写出这个触发器。
  2. 第二个需求则是在日期发生变动的时候,需要对配置表插入一条数据

这样我们可以把这两个需求写在一个触发器当中。


相关文章
|
2月前
|
SQL 关系型数据库 MySQL
SQL中,可以使用 `ORDER BY` 子句来实现排序功能
【10月更文挑战第26天】SQL中,可以使用 `ORDER BY` 子句来实现排序功能
183 6
|
2月前
|
SQL 关系型数据库 MySQL
MySql5.6版本开启慢SQL功能-本次采用永久生效方式
MySql5.6版本开启慢SQL功能-本次采用永久生效方式
48 0
|
4月前
|
SQL 运维 程序员
一个功能丰富的SQL审核查询平台
一个功能丰富的SQL审核查询平台
103 2
|
5月前
|
SQL 流计算
Flink SQL 在快手实践问题之Window TVF改进窗口聚合功能如何解决
Flink SQL 在快手实践问题之Window TVF改进窗口聚合功能如何解决
45 1
|
5月前
|
SQL 存储 OLAP
OneSQL OLAP实践问题之Flink SQL Gateway的功能如何解决
OneSQL OLAP实践问题之Flink SQL Gateway的功能如何解决
56 1
|
6月前
|
SQL
解锁 SQL Server 2022的时间序列数据功能
【7月更文挑战第14天】要解锁SQL Server 2022的时间序列数据功能,可使用`generate_series`函数生成整数序列,例如:`SELECT value FROM generate_series(1, 10)。此外,`date_bucket`函数能按指定间隔(如周)对日期时间值分组,这些工具结合窗口函数和其他时间日期函数,能高效处理和分析时间序列数据。更多信息请参考官方文档和技术资料。
|
6月前
|
存储 运维 监控
函数计算产品使用问题之如何在控制台配置HTTP触发器并使用HTTP请求触发
阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。
|
5月前
|
SQL 存储 数据管理
深入理解SQL中的触发器
【8月更文挑战第31天】
121 0
|
5月前
|
SQL 数据处理 数据库
SQL正则表达式应用:文本数据处理的强大工具——深入探讨数据验证、模式搜索、字符替换等核心功能及性能优化和兼容性问题
【8月更文挑战第31天】SQL正则表达式是数据库管理和应用开发中处理文本数据的强大工具,支持数据验证、模式搜索和字符替换等功能。本文通过问答形式介绍了其基本概念、使用方法及注意事项,帮助读者掌握这一重要技能,提升文本数据处理效率。尽管功能强大,但在不同数据库系统中可能存在兼容性问题,需谨慎使用以优化性能。
77 0
|
5月前
|
SQL 数据库 UED
SQL查询功能的全面解析与实用技巧
SQL(Structured Query Language)作为数据库管理的核心语言,其查询功能是实现数据检索、分析和报告的关键

热门文章

最新文章

下一篇
开通oss服务