sql触发器(下)
1、考虑为什么要设计出发器,为解决什么问题而设计?
2、应制定的内容:为什么,大家思考一下?不知道,看下面的例子,全看完!
T-SQL语句创建触发器
语法结构:
以下是引用片段:
create trigger 触发器名
on 表或视图
for|after|instead of –操作时机
insert,update,delete
as
sql语句
作业:
(要求:在northwind表中建立2个表:cust_test和order_test)
以下是引用片段:
cust_test: CustomerID char(5) PK
order_test: CustomerID char(5)–对应关系
Custcity Orderid PK
Custname OrderNames
CStatus int OStatus int –状态
Cstorage int Orders int –定购量和库存量
Cdate date Odate date–日期
作业1:
在cust_test表中建立删除触发器,实现上述2表的级联删除。
作业2:
在order_test表建立insert触发器,当向order_test表插入一行,如果cust_test表中对应记录status值为1,说明处于准备状态不能写入该数据。
以下是引用片段:
答案1:
use northwind
go
create trigger cust_orders_del1
on Cust_test
after delete
as
delete from order_test
where CustomerID in
(select CustomerID from deleted)
go
答案2:
use northwind
go
create trigger cust_orders_ins2
on order_test
after insert
as
if (select cstatus from cust_test,inserted
where cust_test.customerid=inserted.customerid)=1
begin
print ’The Goods is being processed’
rollback transaction
end
go
图形化操作触发器
11.3 查看触发器情况
图形化操作结合T-SQL命令
(1)sp_helptrigger 触发器名
查看触发器的名称,拥有者和五个布尔值
以下是引用片段:
supdate,isdelete,isinsert,isafter,isinsteadof
(2)sp_helptext 触发器名
查看文本信息
(3)设置某一触发器的无效和重新有效
以下是引用片段:
无效:
use northwind
alter table 表名
disable trigger 触发器名
重新有效:
use northwind
alter table 表名
enable trigger 触发器名
(4)删除触发器
以下是引用片段:
use northwind
drop trigger 触发器名,触发器名
作业3:
在order_test表上建立一个插入触发器,在添加一个订单时,减少cust_test表的相应货物的记录的库存量。
作业4:
在order_test表上建立一个插入触发器,规定订单日期(Odate)不能手工修改。
作业5:
要求订购的物品一定要在仓库中有的,并且数量足够。
作业6:
在order_test表上建立一个插入触发器,同时插入多行数据时,要求订购的物品一定要在仓库中有的。
答案3:
以下是引用片段:
use northwind
go
create trigger cust_orders_ins3
on order_test
after insert
as
update cust_test
set cstorage=cstorage-inserted.orders
from cust_test,inserted
where cust_test.customerid=inserted.customerid
答案4:
以下是引用片段:
use northwind
go
create trigger orderdateupdate
on order_test
after update
as
if update (odate)
begin
raiserror(’Error’,10,1)
rollback transaction
end
答案5:
以下是引用片段:
use northwind
go
create trigger order_insert5
on order_test
after insert
as
begin
if(select count(*)
from cust_test,inserted
where cust_test.customerid=inserted.customerid)=0
begin
print ’No entry in goods for your order’
rollback transaction
end
if(select cust_test.cstorage from cust_test,inserted
where cust_test.customerid=inserted.customerid)<
(select inserted.orders from cust_test,inserted
where cust_test.customerid=inserted.customerid)
begin
print ’No enough entry in goods for your order’
rollback transaction
end
end
答案6:
以下是引用片段:
use northwind
go
create trigger order_insert6
on order_test
after insert
as
if
(select count(*) from cust_test,inserted
where cust_test.customerid=inserted.customerid)<>@@rowcount
–可以在触发器逻辑中使用 @@ROWCOUNT 函数以区分单行插入和多行插入。
begin
delete order_test from order_test,inserted
where order_test.orderid=inserted.orderid and
inserted.customerid not in (select customerid from cust_test)
end
print @@rowcount
Transact-SQL 参考
SET ROWCOUNT
使 Microsoft? SQL Server? 在返回指定的行数之后停止处理查询。
语法
以下是引用片段:
SET ROWCOUNT { number | @number_var }
参数
以下是引用片段:
number | @number_var
是在停止给定查询之前要处理的行数(整数)。
注释
建议将当前使用 SET ROWCOUNT 的 DELETE、INSERT 和 UPDATE 语句重新编写为使用 TOP 语法。有关更多信息,请参见 DELETE、INSERT 或 UPDATE。
对于在远程表和本地及远程分区视图上执行的 INSERT、UPDATE 和 DELETE 语句,忽略 SET ROWCOUNT 选项设置。
若要关闭该选项(以便返回所有的行),请将 SET ROWCOUNT 指定为 0。
说 明 设置 SET ROWCOUNT 选项将使大多数 Transact-SQL 语句在已受指定数目的行影响后停止处理。这包括触发器和 INSERT、UPDATE 及 DELETE 等数据修改语句。ROWCOUNT 选项对动态游标无效,但限制键集的行集和不感知游标。使用该选项时应谨慎,它主要与 SELECT 语句一起使用。
如果行数的值较小,则 SET ROWCOUNT 替代 SELECT 语句 TOP 关键字。
SET ROWCOUNT 的设置是在执行或运行时设置,而不是在分析时设置。
权限
SET ROWCOUNT 权限默认授予所有用户。
示例
SET ROWCOUNT 在指定的行数后停止处理。在下例中,注意有 x 行满足预付款少于或等于 $5,000 的条件;但是,从更新所返回的行数中可以看出并非所有的行都得到处理。ROWCOUNT 影响所有的 Transact-SQL 语句。
以下是引用片段:
USE pubs
GO
SELECT count(*) AS Cnt
FROM titles
WHERE advance >= 5000
GO
下面是结果集:
以下是引用片段:
Cnt
———–
11
(1 row(s) affected)
现在,将 ROWCOUNT 设置为 4,并更新预付款等于或大于 $5,000 的所有行。
SET ROWCOUNT to 4.
SET ROWCOUNT 4
GO
UPDATE titles
SET advance = 5000
WHERE advance >= 5000
GO