自动更新工期触发器(MYSQL)

触发器(Trigger)是一种数据库对象,它在特定事件发生时自动执行的存储过程。通常,触发器会在插入、更新或删除数据时自动触发,并且可以用来维护数据完整性、记录审计日志、实现复杂的业务逻辑等。

项目施工完成 自动计算工期的触发器

项目表

java 复制代码
CREATE TABLE IF NOT EXISTS construction (
    id INT PRIMARY KEY AUTO_INCREMENT COMMENT '施工记录ID',
    project_name VARCHAR(255) NOT NULL COMMENT '项目名称',
    start_date DATE COMMENT '施工开始日期',
    end_date DATE COMMENT '施工结束日期',
    duration INT COMMENT '工期(天,自动计算)'
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

创建触发器

需要创建两个触发器,分别处理插入新记录更新已有记录 时的工期计算,确保当end_date不为空且start_date也不为空时,自动计算工期。

java 复制代码
-- 创建更新前触发的触发器
CREATE TRIGGER calc_duration_before_update
BEFORE UPDATE ON construction
FOR EACH ROW
BEGIN
    -- 当结束日期和开始日期都不为空时,重新计算工期
    IF NEW.end_date IS NOT NULL AND NEW.start_date IS NOT NULL THEN
        SET NEW.duration = DATEDIFF(NEW.end_date, NEW.start_date);
    END IF;


DELIMITER ;




-- 创建更新前触发的触发器
CREATE TRIGGER calc_duration_before_update
BEFORE UPDATE ON construction
FOR EACH ROW
BEGIN
    -- 当结束日期和开始日期都不为空时,重新计算工期
    IF NEW.end_date IS NOT NULL AND NEW.start_date IS NOT NULL THEN
        SET NEW.duration = DATEDIFF(NEW.end_date, NEW.start_date);
    END IF;


DELIMITER ;

触发器说明

触发时机BEFORE INSERTBEFORE UPDATE,确保在数据写入表之前完成工期计算。

计算逻辑 :使用DATEDIFF(end_date, start_date)函数计算两个日期的天数差(结果为整数,正数表示正常工期,负数表示开始日期晚于结束日期,可根据业务需求调整)。

触发条件 :仅当end_date(结束日期)和start_date(开始日期)都不为空时才计算,避免空值导致的错误。

触发器生效测试

假设现在有一个项目的记录如下:

复制代码
java 复制代码
INSERT INTO construction (project_name, start_date, end_date) 
VALUES ('办公楼装修', '2023-01-01', '2023-01-10');

更新结束日期(自动重新计算工期)

java 复制代码
UPDATE construction 
SET end_date = '2023-01-15' 
WHERE id = 1;

结果

通过触发器,即可实现当施工结束日期不为空时自动计算工期的功能。

相关推荐
Greyson14 分钟前
c++ grpc拦截器 c++如何实现grpc的客户端和服务端interceptor
jvm·数据库·python
SilentSamsara4 分钟前
etcd 运维:数据一致性、备份恢复与性能调优
运维·服务器·数据库·kubernetes·kubectl·k8s·etcd
m0_515098427 分钟前
如何增加RAC节点_addnode.sh脚本执行与实例扩展全流程
jvm·数据库·python
LiAo_1996_Y7 分钟前
SQL中如何获取所有列的数据:SELECT -星号用法与性能影响
jvm·数据库·python
qq_654366988 分钟前
生产环境mysql如何实现高可用_配置主从复制与自动故障切换
jvm·数据库·python
2301_8166602112 分钟前
c++ openimageio工具 c++如何使用oiiotool进行图像批量处理
jvm·数据库·python
Kristrina14 分钟前
MySQL大小写敏感、MySQL设置字段大小写敏感
数据库·mysql
Teable任意门互动16 分钟前
多维表格本地化部署实践解析,企业如何实现数据自主可控路径
数据库·低代码·信息可视化·开源·数据库开发
曼岛_16 分钟前
[逆向工程]160个CrackMe入门实战之Andrnalin.2解析(九)
java·数据库·microsoft·逆向
m0_3776182317 分钟前
SQL性能调优:为何尽量使用窗口函数而非关联子查询
jvm·数据库·python