SQL Server触发器之图形化操作 |
本文标签:SQL Server触发器 以下的文章主要向大家讲述的是图形化操作SQL Server触发器的实际应用,如果你在图形化操作SQL Server触发器的实际应用中存在不解之处时,你不妨浏览下面的文章,希望你能从中获得自己想要的东西 。 查看触发器情况
图形化操作结合T-SQL命令 (1)sp_helptrigger 触发器名 查看触发器的名称,拥有者和五个布尔值 supdate,isdelete,isinsert,isafter,isinsteadof (2)sp_helptext 触发器名 查看文本信息 (3)设置某一SQL Server触发器的无效和重新有效 无效: use northwind alter table 表名 disable trigger 触发器名 重新有效: use northwind alter table 表名 enable trigger 触发器名 (4)删除触发器 use northwind drop trigger 触发器名,触发器名 作业3: 在order_test表上建立一个插入SQL Server触发器,在添加一个订单时,减少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 参考
使 Microsoft? SQL Server? 在返回指定的行数之后停止处理查询 。 语法
参数
是在停止给定查询之前要处理的行数(整数) 。 注释 建议将当前使用 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 语句 。
下面是结果集: Cnt ----------- 11 (1 row(s) affected) 现在,将 ROWCOUNT 设置为 4,并更新预付款等于或大于 $5,000 的所有行 。
以上的相关内容就是对图形化操作SQL Server触发器的介绍,望你能有所收获 。 |