SQLServer存储过程编程经验技巧

来源:微软认证    发布时间:2012-11-08    微软认证视频    评论


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中文版测试通过) 

上一页12下一页

视频学习

我考网版权与免责声明

① 凡本网注明稿件来源为"原创"的所有文字、图片和音视频稿件,版权均属本网所有。任何媒体、网站或个人转载、链接转贴或以其他方式复制发表时必须注明"稿件来源:我考网",违者本网将依法追究责任;

② 本网部分稿件来源于网络,任何单位或个人认为我考网发布的内容可能涉嫌侵犯其合法权益,应该及时向我考网书面反馈,并提供身份证明、权属证明及详细侵权情况证明,我考网在收到上述法律文件后,将会尽快移除被控侵权内容。

最近更新

社区交流

考试问答