SQL Server触发器之图形化操作

数据库 SQL Server
以下的文章是通过图形化操作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 参考

 

  1. SET ROWCOUNT 

使 Microsoft? SQL Server? 在返回指定的行数之后停止处理查询。

语法

 

  1. SET ROWCOUNT { number | @number_var } 

参数

 

  1. 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 语句。

 

  1. USE pubs GO SELECT count(*) AS Cnt FROM titles WHERE advance >= 5000 GO 

下面是结果集:

Cnt ----------- 11 (1 row(s) affected) 现在,将 ROWCOUNT 设置为 4,并更新预付款等于或大于  $5,000 的所有行。

  1. SET ROWCOUNT to 4. SET ROWCOUNT 4 GO UPDATE titles SET advance = 5000 WHERE advance >= 5000 GO 

以上的相关内容就是对图形化操作SQL Server触发器的介绍,望你能有所收获。 

【编辑推荐】

  1. SQL Server备份文件中对现存数据库的导入
  2. SQL Server 2000重建索引的实际操作流程
  3. 改善SQL Server安全规划的6步骤
  4. SQL Server 2000文件损坏的修复方案
  5. SQL Server2000安装中的提示挂起的解决

 

责任编辑:佚名 来源: 比特网
相关推荐

2010-09-13 17:03:34

sql server触

2009-04-07 13:56:03

SQL Server触发器实例

2010-11-08 11:49:24

SQL Server管

2010-10-22 11:10:43

SQL Server触

2010-10-20 14:34:48

SQL Server触

2010-07-06 14:47:03

SQL Server数

2010-11-12 15:35:55

SQL Server约

2010-07-16 10:19:31

2010-11-10 13:37:01

SQL Server触

2011-03-28 10:05:57

sql触发器代码

2011-03-03 09:30:24

downmoonsql登录触发器

2010-04-19 10:43:27

SQL Server

2010-10-19 15:31:40

sql server触

2010-07-19 09:50:58

SQL Server2

2019-10-22 07:50:45

SqlServer数据库触发器

2009-06-27 18:35:00

LinuxNFS图形化

2010-07-05 11:01:37

Sql Server触

2010-04-15 15:32:59

Oracle操作日志

2010-09-01 16:40:00

SQL删除触发器

2011-04-01 16:35:09

SQL Server数触发器
点赞
收藏

51CTO技术栈公众号