sql server触发器操作实例

DML触发器分为:
1、 after触发器(之后触发)
a、 insert触发器
b、 update触发器
c、 delete触发器

2、 instead of 触发器 (之前触发)

其中after触发器要求只有执行某一操作insert、update、delete之后触发器才被触发,且只能定义在表上。而instead of触发器表示并不执行其定义的操作(insert、update、delete)而仅是执行触发器本身。既可以在表上定义instead of触发器,也可以在视图上定义。

触发器有两个特殊的表:插入表(instered表)和删除表(deleted表)。这两张是逻辑表也是虚表。有系统在内存中创建者两张表,不会存储在数据库中。而且两张表的都是只读的,只能读取数据而不能修改数据。这两张表的结果总是与被改触发器应用的表的结构相同。当触发器完成工作后,这两张表就会被删除。Inserted表的数据是插入或是修改后的数据,而deleted表的数据是更新前的或是删除的数据。


建库建表:

USE master
GO
--检验数据库是否存在,如果为真,删除此数据库--
IF exists(SELECT * FROM sysdatabases WHERE name='BOOKDB')
  DROP DATABASE BOOKDB
GO
CREATE DATABASE BOOKDB
GO
 
--建数据表--
USE BOOKDB
GO
CREATE TABLE book  --图书表
(
  BID  CHAR(10) primary key, --图书编号
  title  CHAR(50) NOT NULL,  --书名
  author  CHAR(20) NOT NULL, --作者
)
GO
CREATE TABLE book_copy  --图书备份表
(
  BID  CHAR(10) primary key, --图书编号
  title  CHAR(50) NOT NULL,  --书名
  author  CHAR(20) NOT NULL, --作者
)
GO
--图书信息表中插入数据--
INSERT INTO book(BID,title,author)VALUES('B001','人生若只如初见','安意如')
INSERT INTO book(BID,title,author)VALUES('B002','入学那天遇见你','晴空')
INSERT INTO book(BID,title,author)VALUES('B003','感谢折磨你的人','如娜')
INSERT INTO book(BID,title,author)VALUES('B004','我不是教你诈','刘庸')
INSERT INTO book(BID,title,author)VALUES('B005','英语四级','白雪')

触发器实例:

--delete删除类型触发器
if (object_id('tgr_book_delete', 'TR') is not null)
    drop trigger tgr_book_delete
go
create trigger tgr_book_delete
on book
    for delete --删除触发
as
    print '备份数据中……';    
    if (object_id('book_copy', 'U') is not null)
        --存在book_copy,直接插入数据
        insert into book_copy select * from deleted;
    else
        --不存在classesBackup创建再插入
        select * into book_copy from deleted;
    print '备份数据成功!';
go
--
--不显示影响行数
--set nocount on;

测试:
delete book where BID = 'B001' or BID='B005';
select * from book;
select * from book_copy;





  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值