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触发器案例
- [Microsoft.SqlServer.Server.SqlTrigger(Name="Trigger1",Target="ERP_STOCKYaoHuoDingDan",Event="FORINSERT")]
- publicstaticvoidDingDanIDSameGongYingShangGUIDMustSame()
- {
- using(SqlConnectionconnection=newSqlConnection(@"contextconnection=true"))
- {
- connection.Open();
- SqlCommandcommand=newSqlCommand(@"SELECTCOUNT(A.DingDanID)FROMERP_STOCKYaoHuoDingDanASA,INSERTEDASBWHEREA.DingDanID=B.DingDanIDANDA.GongYingShangGUID<>B.GongYingShangGUID",connection);
- inti=(int)command.ExecuteScalar();
- if(i>0)
- {
- try
- {
- //如果要插入的记录不合法,则回滚.
- TransactionTransactiontrans=Transaction.Current;
- trans.Rollback();
- }
- catch(SqlExceptionex)
- {
当在触发器内部调用Transaction.Rollback方法时,将引发异常并显示不明确的错误消息,必须在try/catch块中包装此方法或命令。您会看到如下错误消息:
- Msg6549,Level16,State1,Proceduretrig_InsertValidator,Line0A.NETFrameworkerroroccurredduringexecutionofuserdefinedroutineoraggregate
- 'trig_InsertValidator':System.Data.SqlClient.SqlException:Transactionisnotallowedtorollbackinsideauserdefinedroutine,
- triggeroraggregatebecausethetransactionisnotstartedinthatCLRlevel.Changeapplicationlogictoenforcestricttransactionnesting…Usertransaction,ifany,willberolledback.
- 此异常是预期行为,需要try/catch块才能继续执行代码。当完成执行触发器代码时,将引发另一个异常。
- Msg3991,Level16,State1,Proceduretrig_InsertValidator,Line1Thecontexttransactionwhichwasactivebeforeenteringuserdefinedroutine,
- triggeroraggregate"trig_InsertValidator"hasbeenendedinsideofit,whichisnotallowed.Changeapplicationlogictoenforcestricttransactionnesting.
- Thestatementhasbeenterminated.此异常也是预期行为。
- }
- }
- connection.Close();
- }
- }
调用CLR触发器的例子
尽管引发了两个异常,仍可以回滚事务,并且更改不会提交到表中。
- try
- {
- //用到此触发器的方法
- }
- catch(SqlExceptionex)
- {
- if(ex.Number==3991)
- {
- LabelInfor.Text="同一张订单必须是同一家供应商。";
- }
- }
- catch(Exceptionex)
- {
- }
标题名称:分析概括CLR触发器的例子
文章来源:http://www.shufengxianlan.com/qtweb/news2/119702.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联