您的位置: 首页 计算机类> 微软认证> 心得技巧
公务员考试辅导课程

SQLServer存储过程编程经验技巧

发布时间:06-20

来 源:

页 数:2页

上一篇:找工不想吃闭门羹入行必备MCSE+CCNA

下一篇:Backdoor.Win32.IRCBot.aba分析报告



5、在存储过程中调用外部的ActiveX DLL程序  

  有些特殊的情况下,我们可能会需要调用外部的ActiveX DLL程序,这个时候就需要使用到系统的存储过程sp_OACreate以及其他的相关系统存储过程,都是以sp_OA开头的存储过程,可以自由的在自己的存储过程当中调用ActiveX DLL的各种方法和属性。比如下面的例子: 

  DECLARE @object int  

  DECLARE @hr int  

  DECLARE @property varchar(255)  

  DECLARE @return varchar(255)  

  DECLARE @src varchar(255), @desc varchar(255)  
  -- 建立一个对象(SQLDMO.SQLServer).  

  EXEC @hr = sp_OACreate 'SQLDMO.SQLServer', 
@object  OUT  

  IF @hr <> 0  

  BEGIN  

     EXEC sp_OAGetErrorInfo @object, @src OUT, @desc  OUT   

     SELECT hr=convert(varbinary(4),@hr), 
Source=@src, Description=@desc  

      RETURN  

  END  

  -- 设置对象的属性.  

  EXEC @hr = sp_OASetProperty @object, 'HostName', 'Gizmo'  

  IF @hr <> 0  

  BEGIN  

     EXEC sp_OAGetErrorInfo @object, @src OUT, @desc  OUT   

     SELECT hr=convert(varbinary(4),@hr), 
Source=@src, Description=@desc  

      RETURN  

  END  

  -- 通过OUTPUT参数获取对象的属性值.  

  EXEC @hr = sp_OAGetProperty @object, 'HostName', @property OUT  

  IF @hr <> 0  

  BEGIN  

     EXEC sp_OAGetErrorInfo @object, @src OUT, @desc  OUT   

     SELECT hr=convert(varbinary(4),@hr), Source=@src, Description=@desc  

      RETURN  

  END  

  PRINT @property  

  -- 调用对象的方法  

  EXEC @hr = sp_OAMethod @object, 'Connect', NULL, 'my_server', 'my_login', 'my_password'  

  IF @hr <> 0  

  BEGIN  

     EXEC sp_OAGetErrorInfo @object, @src OUT, @desc  
OUT   

     SELECT hr=convert(varbinary(4),@hr), Source=@src, Description=@desc  

      RETURN  

  END  

  -- 销毁已经创建的ActiveX对象  

  EXEC @hr = sp_OADestroy @object  

  IF @hr <> 0  

  BEGIN  

     EXEC sp_OAGetErrorInfo @object, @src OUT, @desc  
OUT   

     SELECT hr=convert(varbinary(4),@hr), Source=@src, Description=@desc  

      RETURN  

  END  

  6、在存储过程中使用数据库事务处理  

  在很多的情况下,我们在存储过程中都会遇到需要同时操作多个表的情况,这时候就需要避免在操作的过程中由于以外而造成的数据的不一致性。这时候就需要将操作多个表的操作放入到事务中进行处理。  

  但是需要注意的是,不能在事务中使用return语句强行退出,这样会引发事务的非正常错误,不能保证数据的一致性。  

  并且,一旦将多个处理放入事务当中,系统的处理速度会有所降低,所以应当将频繁操作的多个可分割的处理过程放入到多个存储过程当中,这样会大大提高系统的响应速度,但是前提是不违背数据的一致性。 

  看完了上面的这些编写SQL Server存储过程当中的技巧,相信对您或多或少会有些帮助,也希望通过上面的一些经验总结,可以使得您在应用SQL Server存储过程的时候,有意识的可以避免一些弯路。  

  (以上所有程序在Windows Advance Server2000中文版+MS SQL Server7.0/2000中文版测试通过) 





     

考试信息

热点排行

最近更新

考试辅导

网校辅导

面授培训

©2006-2008 100ksw.com 版权所有 皖ICP备06013378号