SQL触发器实例(上)

Posted 风中男子

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL触发器实例(上)相关的知识,希望对你有一定的参考价值。

  1 --1.) 创建测试用的表(testTable)
  2 if exists (select * from sysobjects where name=testTable)
  3 drop table testTable
  4 GO
  5 Create Table testTable
  6 (
  7 testField varchar(50)
  8 )
  9 
 10  select * from testTable
 11 
 12 
 13 
 14 --2.) 创建基于表(testTable)的触发器(testTrigger)
 15 IF EXISTS (Select name FROM sysobjects Where name = testTrigger AND type = TR)
 16 Drop TRIGGER testTrigger
 17 GO
 18 Create Trigger testTrigger 
 19 ON testTable 
 20 for Insert,Delete,Update
 21 AS
 22 if exists(select * from inserted)
 23      if exists(select * from deleted)
 24          print ...更新
 25      else
 26          print ...插入
 27 else
 28      if exists(select * from deleted)
 29          print ...删除
 30 Go
 31 
 32 
 33 --.) 操作testTable表,测试触发器testTrigger
 34 --分别执行Insert Into语句,Update语句,Delete语句,看看效果
 35 Insert Into testTable values (testContent!)
 36 
 37 Update testTable Set testField = UpdateContent
 38 
 39 Delete From testTable
 40 
 41 select * from testTable
 42 
 43 
 44 --用到的功能有: 
 45         --1.如果我更改了学生的学号,我希望他的借书记录仍然与这个学生相关(也就是同时更改借书记录表的学号); 
 46         --2.如果该学生已经毕业,我希望删除他的学号的同时,也删除它的借书记录,等等。
 47 
 48  --这时候可以用到触发器。对于需求1,创建一个Update触发器: 
 49 
 50      Create Trigger truStudent 
 51 
 52        On student      --在Student表中创建触发器 
 53        instead of Update      --为什么事件触发 
 54      As           --事件触发后所要做的事情 
 55        if Update(stuID)            
 56        begin 
 57 
 58          Update borrow 
 59            Set stuID=i.stuID 
 60            From borrow as br , Deleted as d ,Inserted as i      --Deleted和Inserted临时表 
 61            Where br.stuID=d.stuID 
 62 
 63        end   
 64 
 65 drop trigger truStudent
 66 UPDATE student set stuID=1006 WHERE stuID=1005
 67 
 68 
 69     Create trigger trdStudent
 70        On Student 
 71        instead of Delete 
 72      As 
 73      Delete Borrow 
 74    From Borrow as br , Deleted as d Where br.StuID=d.stuID 
 75 
 76 drop trigger trdStudent
 77 delete FROM student WHERE stuID=1004
 78 
 79 disable trigger trdStudent on Student
 80 
 81 select * from book
 82 select * from borrow
 83 select * from student
 84 
 85 
 86 --创建触发器(对删除表的约束)
 87 create trigger droptabel
 88 on database
 89 for drop_table
 90 as
 91 print删除表吗?
 92 print不能删除表
 93 rollback transaction
 94 go
 95 
 96 drop table students
 97 disable trigger droptabel on database    --关闭触发器
 98 enable trigger droptabel on database
 99 
100 
101 
102 
103 
104 CREATE TABLE students  --学生信息表
105 (
106   stuID CHAR(10) primary key,  --学生编号
107   stuName  CHAR(10) NOT NULL ,     --学生名称
108   major  CHAR(50) NOT NULL    --专业
109 )
110 GO
111 
112 
113 CREATE TABLE borrowS  --借书表
114 (
115  borrowID  CHAR(10) primary key,    --借书编号
116 stuID CHAR(10) NOT NULL, --学生编号
117 BID  CHAR(10) NOT NULL,--图书编号
118  T_time  datetime NOT NULL,   --借出日期
119  B_time  datetime    --归还日期
120 )
121 GO
122 
123 SElect * from students
124 select * from borrows
125 
126 Create Trigger truStudents 
127 
128        On students      --在Student表中创建触发器 
129        for Update      --为什么事件触发 
130      As           --事件触发后所要做的事情 
131        if Update(stuID)            
132        begin 
133 
134          Update borrows 
135            Set stuID=i.stuID 
136            From borrows as br , Deleted as d ,Inserted as i      --Deleted和Inserted临时表 
137            Where br.stuID=d.stuID 
138 
139        end   
140 
141 
142 
143 UPDATE studentS set stuID=1006 WHERE stuID=1005
144 
145 
146     Create trigger trStudent
147        On Students 
148        for Delete 
149      As 
150        Delete borrows 
151          From borrows AS br , Deleted AS d 
152          Where br.stuID=d.stuID 
153 
154 
155 drop trigger trStudent
156 
157 
158 delete from students where stuID=1001

 

以上是关于SQL触发器实例(上)的主要内容,如果未能解决你的问题,请参考以下文章

MySQL触发器

t-sql如何创建连接2台服务器的触发器

使用触发器对学生表操作进行日志记录

sql server 的after触发器之insert触发器实例

使用实体框架迁移时 SQL Server 连接抛出异常 - 添加代码片段

spark关于join后有重复列的问题(org.apache.spark.sql.AnalysisException: Reference '*' is ambiguous)(代码片段