分析概括CLR触发器的例子

开发 后端
文章主要介绍了创建CLR对象三大步1.在解决方案中添加新的C#SQL数据库项目命名为“ServiceClient”2为你的目标数据库选择或添加注释 3.为创建的服务添加声明。

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)  

当在触发器内部调用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. }  

调用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. }  

【编辑推荐】

  1. 使用CLR存储过程来传回讯息实战案例
  2. 经典案例之创建CLR存储过程
  3. 概括Visual Studio CLR调试器两种方法
  4. Visual Studio中SQL SERVER CLR代码调试工具使用讲解
  5. CLR函数压缩NTEXT类型字段实例讲解
责任编辑:田树 来源: 博客
相关推荐

2009-09-18 14:31:33

CLR触发器

2011-05-20 14:06:25

Oracle触发器

2010-05-19 09:40:05

MySQL触发器

2011-05-19 14:29:49

Oracle触发器语法

2011-04-14 13:54:22

Oracle触发器

2010-05-31 18:06:07

MySQL 触发器

2010-10-12 10:04:15

MySQL触发器

2009-10-22 13:47:12

CLR调试器

2011-03-28 10:05:57

sql触发器代码

2009-04-07 13:56:03

SQL Server触发器实例

2010-10-11 14:52:43

Mysql触发器

2010-05-18 15:36:44

MySQL触发器

2009-04-26 22:27:54

触发器密码修改数据库

2011-03-03 09:30:24

downmoonsql登录触发器

2009-11-18 13:15:06

Oracle触发器

2021-07-30 10:33:57

MySQL触发器数据

2010-10-12 10:24:58

mysql触发器

2010-05-18 15:58:39

MySQL触发器

2010-10-20 14:34:48

SQL Server触

2010-10-12 09:41:26

mysql触发器
点赞
收藏

51CTO技术栈公众号