SQL Server:触发器实例详解

SQL Server:触发器实例详解

在 SQL Server 中,触发器是一种与表相关联的特殊存储过程,它们在对表进行 INSERT、UPDATE 或 DELETE 操作时自动执行。

触发器的类型

SQL Server 支持以下两种类型的触发器:

  1. 行触发器(Row Triggers):当某个行受到影响时,该触发器会被激活。例如,对某个行进行 INSERT、UPDATE 或 DELETE 操作时。

  2. 语句触发器(Statement Triggers):当执行某个 INSERT、UPDATE 或 DELETE 语句时,该触发器会被激活。

创建触发器

在创建触发器之前,我们需要确定以下信息:

  1. 触发器所属的表名。
  2. 触发器激活的 INSERT、UPDATE 或 DELETE 操作类型。
  3. 激活触发器时的条件。
  4. 触发器所执行的操作。

创建触发器的语法:

CREATE TRIGGER [触发器名称]
[ON TableName]
[FOR INSERT, UPDATE, DELETE]
[AS]
BEGIN
    -- 触发器执行的语句
END;

触发器实例

示例 1:创建行触发器

假设我们在 Employee 表上创建了一个行触发器,当执行某个 UPDATE 操作时,如果更新的数据中薪水字段 Salary 大于 5000,则让该记录返回上一个状态。

CREATE TRIGGER Trig_Employee_Update
ON Employee
FOR UPDATE
AS
BEGIN
    DECLARE @OldValue DECIMAL(8, 2);
    SET @OldValue = (SELECT Salary FROM DELETED);
    IF (UPDATE(Salary) AND @OldValue > 5000)
    BEGIN
        RAISERROR ('Cannot update salary to a value greater than 5000.', 16, 1);
        ROLLBACK TRANSACTION;
        RETURN;
    END;
END;

上面的代码中,Trig_Employee_Update 是触发器的名称,Employee 是触发器所属的表名,FOR UPDATE 表示当执行 UPDATE 操作时触发器会被激活。

DECLARE 语句用于声明并定义一个局部变量,SET 语句用于给该变量赋值。由于我们需要检查修改前的薪水值,所以需要使用 DELETED 临时表来获取。

然后使用 IF 语句进行条件判断,判断 Salary 列是否有更新,并且更新后的薪水值是否大于 5000。

最后,如果符合条件,使用 RAISERROR 报错并使用 ROLLBACK TRANSACTION 回滚事务。

示例 2:创建语句触发器

我们可以在 Appointment 表上创建一个语句触发器,每次执行一个 INSERT、UPDATE 或 DELETE 操作时,在日志表 LogAppointment 中生成一条记录。

CREATE TRIGGER Trig_Appointment_Log
ON Appointment
AFTER INSERT, UPDATE, DELETE
AS
BEGIN
    DECLARE @OperationType VARCHAR(10);
    IF EXISTS(SELECT * FROM INSERTED)
    BEGIN
        SET @OperationType = 'INSERT';
    END;
    IF EXISTS(SELECT * FROM UPDATED)
    BEGIN
        SET @OperationType = 'UPDATE';
    END;
    IF EXISTS(SELECT * FROM DELETED)
    BEGIN
        SET @OperationType = 'DELETE';
    END;

    INSERT INTO LogAppointment (OperationType, OperationTime)
    VALUES (@OperationType, GETDATE());
END;

上面的代码中,Trig_Appointment_Log 是触发器的名称,Appointment 是触发器所属的表名,AFTER INSERT, UPDATE, DELETE 表示当执行 INSERT、UPDATE 或 DELETE 语句时触发器会被激活。

使用 IF 语句判断当前操作类型,并根据操作类型插入数据到日志表 LogAppointment 中。

总结

在 SQL Server 中使用触发器可以简化复杂的业务逻辑,在对数据库进行增、删、改操作时执行自定义代码逻辑。要使用触发器,我们需要确定好触发的操作类型和触发的条件,并编写符合要求的代码。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:SQL Server:触发器实例详解 - Python技术站

(0)
上一篇 2023年5月21日
下一篇 2023年5月21日

相关文章

  • oracle sql语言模糊查询–通配符like的使用教程详解

    下面我将为您详细讲解“Oracle SQL语言模糊查询–通配符LIKE的使用教程详解”。 什么是模糊查询 模糊查询是一种常用的SQL查询技巧,用于查找不完全匹配的数据。通常情况下,在SQL查询中,我们使用的是完全匹配的查询,也就是说,当我们需要查询某个字段的准确值时,我们通常使用等于(=)运算符。但是,在实际的查询中,我们往往需要查询不完全匹配的数据,例如…

    database 2023年5月21日
    00
  • Linux mysql-5.6如何实现重置root密码

    当你忘记了mysql的root密码时,可以通过下面的步骤来重置密码: 1. 停止mysql服务 使用以下命令停止mysql服务。 # Ubuntu 或者 Debian sudo /etc/init.d/mysql stop # CentOS 或者 Red Hat sudo systemctl stop mysqld 2. 以系统管理员身份运行mysql 以系…

    database 2023年5月22日
    00
  • Mysql 5.7.9 shutdown 语法实例详解

    MySQL 5.7.9 shutdown 语法实例详解 1. 关闭 MySQL 服务器 要关闭 MySQL 服务器,可以使用以下命令: mysqladmin -u root -p shutdown 当你运行这条命令时,系统将提示输入 MySQL root 用户的密码。输入正确密码后,MySQL 服务器将被正常关闭。 2. 设置 MySQL 服务器关闭模式 可…

    database 2023年5月22日
    00
  • MySQL冷备份所需物理文件

    MySQL冷备份是一种备份方式,它的特点是备份过程中数据库不会被访问或修改。这种备份方式可以在数据库运行期间进行,不会对正常业务产生影响,并且备份文件的大小、恢复速度、稳定性都比较好。 在进行MySQL冷备份时,需要备份一些物理文件。 数据库文件 MySQL的数据库文件通常存储在数据目录下,这些文件包括数据文件(.frm、.ibd等)和日志文件(.ib_lo…

    MySQL 2023年3月10日
    00
  • ORACLE 如何查询被锁定表及如何解锁释放session

    查询被锁定表的方法: 在Oracle DBMS中查询被锁定表可以通过以下几种方式: 1.查询DBA_LOCKS视图 SELECT object_id, session_id, ORACLE_USERNAME, locked_mode FROM dba_locks WHERE lock_type=’TM’ and rownum<=10; 这里查询的loc…

    database 2023年5月21日
    00
  • MySQL REVOKE:删除用户权限

    MySQL是一个非常流行的关系型数据库管理系统,它允许管理员授予和收回用户对数据库的访问权限。当不再需要用户访问数据库时,管理员可以使用MySQL的REVOKE命令来撤销该用户的权限,以保护数据库的安全性。本文将介绍MySQL REVOKE命令的用法和操作步骤。 REVOKE命令的语法和参数 首先,我们来看一下REVOKE命令的语法和参数: REVOKE p…

    MySQL 2023年3月10日
    00
  • SQL2005查看死锁存储过程sp_who_lock

    当多个事务互相等待对方释放资源时,就会发生死锁。在SQL Server 2005中,可以使用存储过程sp_who_lock查看正在发生死锁的会话和相关信息。下面是使用sp_who_lock的完整攻略。 步骤一:创建存储过程sp_who_lock 在SQL Server Management Studio(SSMS)中,使用以下SQL语句创建存储过程sp_wh…

    database 2023年5月21日
    00
  • Myeclipse链接Oracle等数据库时lo exception: The Network Adapter could not establish the connection

    当使用MyEclipse链接Oracle数据库时,可能会遇到“lo exception: The Network Adapter could not establish the connection”错误。这通常是因为数据库的驱动程序没有正确配置而导致的。下面是一个完整的攻略,用于解决这个问题: 确认数据库驱动程序已正确配置 首先,在MyEclipse中打开…

    database 2023年5月18日
    00
合作推广
合作推广
分享本页
返回顶部