分析概括CLR触发器的例子

CLR有很多值得学习的地方,这里我们主要介绍创建CLR对象,包括介绍CLR触发器等方面,希望你可以从中学到东西。

公司主营业务:网站设计、网站建设、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联推出庐山免费做网站回馈大家。

一 创建CLR对象

1.在解决方案中添加新的C#SQL数据库项目,命名为“ServiceClient”
2.为你的目标数据库选择或添加注释。(如果未被提示:右击ServiceClient项目,选择属性,数据库,浏览并选择你的连接)
3.为创建的服务添加声明
1)在解决方案浏览器中右击“service”项目,选择“调试”>“Start New Instance”
2)服务运行:右击“ServiceClient”项目,选择“Add Service Reference”
3)在“Service URI”中输入:http://localhost:8000/services
4)点击“OK”

二 CLR触发器案例

 
 
 
  1. [Microsoft.SqlServer.Server.SqlTrigger(Name="Trigger1",Target="ERP_STOCKYaoHuoDingDan",Event="FORINSERT")]
  2. publicstaticvoidDingDanIDSameGongYingShangGUIDMustSame()
  3. {
  4. using(SqlConnectionconnection=newSqlConnection(@"contextconnection=true"))
  5. {
  6. connection.Open();
  7. SqlCommandcommand=newSqlCommand(@"SELECTCOUNT(A.DingDanID)FROMERP_STOCKYaoHuoDingDanASA,INSERTEDASBWHEREA.DingDanID=B.DingDanIDANDA.GongYingShangGUID<>B.GongYingShangGUID",connection);
  8. inti=(int)command.ExecuteScalar();
  9. if(i>0)
  10. {
  11. try
  12. {
  13. //如果要插入的记录不合法,则回滚.
  14. TransactionTransactiontrans=Transaction.Current;
  15. trans.Rollback();
  16. }
  17. catch(SqlExceptionex)
  18. {

当在触发器内部调用Transaction.Rollback方法时,将引发异常并显示不明确的错误消息,必须在try/catch块中包装此方法或命令。您会看到如下错误消息:

 
 
 
  1. Msg6549,Level16,State1,Proceduretrig_InsertValidator,Line0A.NETFrameworkerroroccurredduringexecutionofuserdefinedroutineoraggregate
  2. 'trig_InsertValidator':System.Data.SqlClient.SqlException:Transactionisnotallowedtorollbackinsideauserdefinedroutine,
  3. triggeroraggregatebecausethetransactionisnotstartedinthatCLRlevel.Changeapplicationlogictoenforcestricttransactionnesting…Usertransaction,ifany,willberolledback.
  4. 此异常是预期行为,需要try/catch块才能继续执行代码。当完成执行触发器代码时,将引发另一个异常。
  5. Msg3991,Level16,State1,Proceduretrig_InsertValidator,Line1Thecontexttransactionwhichwasactivebeforeenteringuserdefinedroutine,
  6. triggeroraggregate"trig_InsertValidator"hasbeenendedinsideofit,whichisnotallowed.Changeapplicationlogictoenforcestricttransactionnesting.
  7. Thestatementhasbeenterminated.此异常也是预期行为。
  8. }
  9. }
  10. connection.Close();
  11. }
  12. }

调用CLR触发器的例子

尽管引发了两个异常,仍可以回滚事务,并且更改不会提交到表中。

 
 
 
  1. try
  2. {
  3. //用到此触发器的方法
  4. }
  5. catch(SqlExceptionex)
  6. {
  7. if(ex.Number==3991)
  8. {
  9. LabelInfor.Text="同一张订单必须是同一家供应商。";
  10. }
  11. }
  12. catch(Exceptionex)
  13. {
  14. }

标题名称:分析概括CLR触发器的例子
文章来源:http://www.hantingmc.com/qtweb/news2/119702.html

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

广告

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