SQLServer触发器之图形化操作

以下的文章主要向大家讲述的是图形化操作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安装中的提示挂起的解决

文章题目:SQLServer触发器之图形化操作
当前路径:http://www.csdahua.cn/qtweb/news10/286960.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网