好文档就是一把金锄头!
欢迎来到金锄头文库![会员中心]
电子文档交易市场
安卓APP | ios版本
电子文档交易市场
安卓APP | ios版本

SQL触发器实例.doc

11页
  • 卖家[上传人]:工****
  • 文档编号:448236874
  • 上传时间:2023-07-02
  • 文档格式:DOC
  • 文档大小:34.50KB
  • / 11 举报 版权申诉 马上下载
  • 文本预览
  • 下载提示
  • 常见问题
    • 精品文档,仅供学习与交流,如有侵权请联系网站删除SQL触发器实例定义: 何为触发器?在SQL Server里面也就是对某一个表的一定的操作,触发某种条件,从而执行的一段程序触发器是一个特殊的存储过程       常见的触发器有三种:分别应用于Insert , Update , Delete 事件       我为什么要使用触发器?比如,这么两个表:       Create Table Student(              --学生表         StudentID int primary key,       --学号         ....        )       Create Table BorrowRecord(               --学生借书记录表         BorrowRecord   int identity(1,1),       --流水号           StudentID      int ,                    --学号         BorrowDate     datetime,                --借出时间         ReturnDAte     Datetime,                --归还时间         ...       )      用到的功能有:         1.如果我更改了学生的学号,我希望他的借书记录仍然与这个学生相关(也就是同时更改借书记录表的学号);         2.如果该学生已经毕业,我希望删除他的学号的同时,也删除它的借书记录。

           等等      这时候可以用到触发器对于1,创建一个Update触发器:      Create Trigger truStudent        On Student                         --在Student表中创建触发器        for Update                          --为什么事件触发      As                                        --事件触发后所要做的事情        if Update(StudentID)                   begin          Update BorrowRecord            Set StudentID=i.StudentID            From BorrowRecord br , Deleted   d ,Inserted i      --Deleted和Inserted临时表            Where br.StudentID=d.StudentID        end                              理解触发器里面的两个临时的表:Deleted , Inserted 。

      注意Deleted 与Inserted分别表示触发事件的表“旧的一条记录”和“新的一条记录”      一个数据库系统中有两个虚拟表用于存储在表中记录改动的信息,分别是:                              虚拟表Inserted                     虚拟表Deleted 在表记录新增时     存放新增的记录                         不存储记录          修改时           存放用来更新的新记录                   存放更新前的记录          删除时           不存储记录                             存放被删除的记录      一个Update 的过程可以看作为:生成新的记录到Inserted表,复制旧的记录到Deleted表,然后删除Student记录并写入新纪录      对于2,创建一个Delete触发器      Create trigger trdStudent        On Student        for Delete      As        Delete BorrowRecord          From BorrowRecord br , Delted d          Where br.StudentID=d.StudentID      从这两个例子我们可以看到了触发器的关键:A.2个临时的表;B.触发机制。

      SQL触发器实例2/* 建立虚拟测试环境,包含:表[卷烟库存表],表[卷烟销售表] 请大家注意跟踪这两个表的数据,体会触发器到底执行了什么业务逻辑,对数据有什么影响 为了能更清晰的表述触发器的作用,表结构存在数据冗余,且不符合第三范式,这里特此说明 */ USE Master GO IF EXISTS (SELECT NAME FROM SYSOBJECTS WHERE XTYPE = ’U’ AND NAME = ’卷烟库存表’) DROP TABLE 卷烟库存表 GO IF EXISTS (SELECT NAME FROM SYSOBJECTS WHERE XTYPE = ’U’ AND NAME = ’卷烟销售表’) DROP TABLE 卷烟销售表 GO --业务规则:销售金额 = 销售数量 * 销售单价 业务规则 CREATE TABLE 卷烟销售表 ( 卷烟品牌 VARCHAR(40) PRIMARY KEY NOT NULL, 购货商 VARCHAR(40) NULL, 销售数量 INT NULL, 销售单价 MONEY NULL, 销售金额 MONEY NULL ) GO --业务规则:库存金额 = 库存数量 * 库存单价 业务规则。

      CREATE TABLE 卷烟库存表 ( 卷烟品牌 VARCHAR(40) PRIMARY KEY NOT NULL, 库存数量 INT NULL, 库存单价 MONEY NULL, 库存金额 MONEY NULL ) GO --创建触发器,示例1 /* 创建触发器[T_INSERT_卷烟库存表],这个触发器较简单 说明: 每当[卷烟库存表]发生 INSERT 动作,则引发该触发器 触发器功能: 强制执行业务规则,保证插入的数据中,库存金额 = 库存数量 * 库存单价 注意: [INSERTED]、[DELETED]为系统表,不可创建、修改、删除,但可以调用 重要: 这两个系统表的结构同插入数据的表的结构 */ IF EXISTS (SELECT NAME FROM SYSOBJECTS WHERE XTYPE = ’TR’ AND NAME = ’T_INSERT_卷烟库存表’) DROP TRIGGER T_INSERT_卷烟库存表 GO CREATE TRIGGER T_INSERT_卷烟库存表 ON 卷烟库存表 FOR INSERT AS --提交事务处理 BEGIN TRANSACTION --强制执行下列语句,保证业务规则 UPDATE 卷烟库存表 SET 库存金额 = 库存数量 * 库存单价 WHERE 卷烟品牌 IN (SELECT 卷烟品牌 from INSERTED) COMMIT TRANSACTION GO /* 针对[卷烟库存表],插入测试数据: 注意,第一条数据(红塔山新势力)中的数据符合业务规则, 第二条数据(红塔山人为峰)中,[库存金额]空,不符合业务规则, 第三条数据(云南映像)中,[库存金额]不等于[库存数量]乘以[库存单价],不符合业务规则。

      第四条数据库存数量为0 请注意在插入数据后,检查[卷烟库存表]中的数据是否 库存金额 = 库存数量 * 库存单价 */ INSERT INTO 卷烟库存表(卷烟品牌,库存数量,库存单价,库存金额) SELECT ’红塔山新势力’,100,12,1200 UNION ALL SELECT ’红塔山人为峰’,100,22,NULL UNION ALL SELECT ’云南映像’,100,60,500 UNION ALL SELECT ’玉溪’,0,30,0 GO --查询数据 SELECT * FROM 卷烟库存表 GO /* 结果集 RecordId 卷烟品牌 库存数量 库存单价 库存金额 -------- ------------ -------- ------- --------- 1 红塔山新势力 100 12.0000 1200.0000 2 红塔山人为峰 100 22.0000 2200.0000 3 云南映像 100 60.0000 6000.0000 4 玉溪 0 30.0000 .0000 (所影响的行数为 4 行) */ --触发器示例2 /* 创建触发器[T_INSERT_卷烟销售表],该触发器较复杂。

      说明: 每当[卷烟库存表]发生 INSERT 动作,则引发该触发器 触发器功能: 实现业务规则 业务规则: 如果销售的卷烟品牌不存在库存或者库存为零,则返回错误 否则则自动减少[卷烟库存表]中对应品牌卷烟的库存数量和库存金额 */ IF EXISTS (SELECT NAME FROM SYSOBJECTS WHERE XTYPE = ’TR’ AND NAME = ’T_INSERT_卷烟销售表’) DROP TRIGGER T_INSERT_卷烟销售表 GO CREATE TRIGGER T_INSERT_卷烟销售表 ON 卷烟销售表 FOR INSERT AS BEGIN TRANSACTION --检查数据的合法性:销售的卷烟是否有库存,或者库存是否大于零 IF NOT EXISTS ( SELECT 库存数量 FROM 卷烟库存表 WHERE 卷烟品牌 IN (SELECT 卷烟品牌 FROM INSERTED) ) BEGIN --返回错误提示 RAISERROR(’错误!该卷烟不存在库存,不能销售’,16,1) --回滚事务 ROLLBACK RETURN END IF EXISTS ( SELECT 库存数量 FROM 卷烟库存表 WHERE 卷烟品牌 IN (SELECT 卷烟品牌 FROM INSERTED) AND 库存数量 <= 0 ) BEGIN --返回错误提示 RAISERROR(’错误!该卷烟库存小于等于0,不能销售。

      ’,16,1) --回滚事务 ROLLBACK RETURN END --对合法的数据进行处理 --强制执行下列语句,保证业务规则 UPDATE 卷烟销售表 SET 销售金额 = 销售数量 * 销售单价 WHERE 卷烟品牌 IN (SELECT 卷烟品牌 FROM INSERTED) DECLARE @卷烟品牌 VARCHAR(40) SET。

      点击阅读更多内容
      相关文档
      四川省成都市2025年中考数学真题试卷附同步解析.docx 四川省成都市锦江区师一学校2024_2025学年下学期八年级数学期中考试卷.docx 四川省成都市2025年中考数学真题试卷含同步解析.pptx 2025年四川省南充市名校联测中考一模数学试卷[含答案].docx 2025年四川省绵阳市游仙区中考一模数学试卷[含答案].docx 2024—2025学年山西省晋中市左权县八年级下学期6月期末数学试题[含答案].docx 2024—2025学年江西省吉安市青原区八年级下学期6月期末数学试题[含答案].docx 2025年四川省绵阳市涪城区中考一模数学试卷[含答案].docx 2025年四川省绵阳市安州区中考模数学试卷[含答案].docx 2024—2025学年江西省赣州市于都县八年级下学期6月期末数学试题[含答案].docx 2024—2025学年江苏省盐城市盐都区七年级下学期6月期末数学试题[含答案].docx 2025年广东省惠州市集团中考一模数学试卷[含答案].docx 2024—2025学年安徽省淮北市濉溪县七年级下学期6月期末考试数学试题[含答案].docx 2025年山东省威海市环翠区中考一模数学试卷[含答案].docx 2025年四川省自贡市富顺县代寺学区中考模拟一模数学试卷[含答案].docx 2024—2025学年湖北省孝感市汉川市八年级下学期6月期末数学试题[含答案].docx 2024—2025学年山西省晋中市左权县七年级下学期6月期末数学试题[含答案].docx 2025年宁夏九年级数学一模试卷[含答案].docx 2025年山东省临沂市中考模拟数学试卷(二)[含答案].docx 2024—2025学年河南省南阳市西峡县八年级下学期6月期末考试数学试题[含答案].docx
      关于金锄头网 - 版权申诉 - 免责声明 - 诚邀英才 - 联系我们
      手机版 | 川公网安备 51140202000112号 | 经营许可证(蜀ICP备13022795号)
      ©2008-2016 by Sichuan Goldhoe Inc. All Rights Reserved.