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)
- {
- }
【编辑推荐】