zoukankan      html  css  js  c++  java
  • SQL触发器

    什么是触发器?
    触发器是一种用来保障参照完整性的特殊的存储过程,它维护不同表中数据间关系的有关规则。当对指定的表进行某种特定操作(如:Insert,Delete或Update)时,触发器产生作用。触发器可以调用存储过程。

    常见的触发器有三种:分别应用于Insert,Update,Delete事件。

    触发器的限制:

    1、一个表最多只能有三个触发器,insert,update,delete
    2、每个触发器只能用于一个表
    3、不能对视图、临时表创建触发器
    4、Truncate table能删除表,但不能触发触发器
    5、不能将触发器用于系统表

    使用触发器的优点
    1、触发器是自动的:它们在对表的数据作了任何修改(比如手工输入或者应用程序采取的操作)之后立即被激活。
    2、触发器可以通过数据库中的相关表进行层叠更改。例如,可以在 titles 表的 title_id 列上写入一个删除触发器,以使其它表中的各匹配行采取删除操作。该触发器用 title_id 列作为唯一键,在 titleauthor、sales 及 roysched 表中对各匹配行进行定位。
    3、触发器可以强制限制,这些限制比用 CHECK 约束所定义的更复杂。与 CHECK 约束不同的是,触发器可以引用其它表中的列。例如,触发器可以回滚试图对价格低于 10 美元的书(存储在 titles 表中)应用折扣。

    --删除触发器
    drop trigger 触发器名称
    --判断触发器是否存在
    if (object_id('触发器名') is not null)
        --删除触发器
        drop trigger 触发器名
    go
    --创建触发器
    if (object_id('触发器名') is not null)
        drop trigger 触发器名
    go
    Create Trigger 触发器名
    On 表名
    For insert/update/delete
    As
    Begin
    SQL语句(块)
    End

    下面在数据表上进行操作触发器,首先创建一个数据表TestTable

    CREATE TABLE TestTable(
     [Id] [int] IDENTITY(1,1) NOT NULL,
     [UserName] [nvarchar](50) NULL,
     [Subject] [nvarchar](50) NULL,
     [Source] [numeric](18, 0) NULL
    ) ON [PRIMARY]
    go
    INSERT INTO TestTable ([UserName],[Subject],[Source]) 
     SELECT N'张三',N'语文',60 UNION ALL
     SELECT N'李四',N'数学',70 UNION ALL
     SELECT N'王五',N'英语',80 UNION ALL
     SELECT N'王五',N'数学',75 UNION ALL
     SELECT N'王五',N'语文',57 UNION ALL
     SELECT N'李四',N'语文',80 UNION ALL
     SELECT N'张三',N'英语',100
    GO

    1、创建insert插入类型触发器,用于判断插入的姓名是否存在,存在则插入失败进行回滚,不存在则插入成功,

    --判断触发器tgr_insert是否存在
    if (object_id('tgr_insert') is not null)
        --删除触发器tgr_insert
        drop trigger tgr_insert
    go
    --创建触发器tgr_insert
    create trigger tgr_insert
    --TestTable表示需要操作的表名
    on TestTable
        for insert --插入触发
    as
    --定义变量
    declare
    @UserName nchar(20),
    @Subject nchar(20),
    @Source int,
    @ishave int;
    --给变量赋值
    select @UserName=UserName,@Subject=Subject,@Source=Source from TestTable
    --查询姓名相同的行数赋值给@ishave
    select @ishave=COUNT(*) from TestTable where UserName=@UserName
    --如果行数大于1表示该姓名已存在
    if(@ishave>1)
    begin
    --print提示信息
    print('插入失败,事务已回滚')
    --事务数据回滚
    Rollback transaction    
    end
    else
    --否则该姓名不存在,则插入成功
    print('插入成功')
    
    --插入数据进行测试,执行两次看输出结果
    insert into TestTable values('张三三','天文',200);
    注:强推一波个人小站:小语雀网 | 欢迎大佬们访问哈~
  • 相关阅读:
    php 上传大文件问题
    两台虚拟机实现负载均衡
    lnmp一键安装包搭建lnmp环境
    PHPExcel在读取时时间的处理
    ZeroMQ研究与应用分析
    堆排序(概念、原理、实现)
    HASH表的实现(拉链法)
    加密和数字签名工具GPG
    我的2014 一言难尽
    MySQL优化之profile
  • 原文地址:https://www.cnblogs.com/zpblogs/p/14679713.html
Copyright © 2011-2022 走看看