设为首页 收藏本站
查看: 578|回复: 0

[经验分享] 在Sql Server的存储过程中调用Com组件

[复制链接]

尚未签到

发表于 2016-11-4 08:19:01 | 显示全部楼层 |阅读模式
  有时候,出于SQL Server本身的功能不足,我们需要用外部的程序来实现,而Com由于其语言的无关性和强大的功能就成为与Sql Server接口的首选,并且sql Server本身也提供了这方面的系统存储过程用以实现与com的接口。这几个相关的系统存储过程为:
sp_OACreate 在SQL Server执行个体建立 OLE 对象的执行个体。
sp_OAMethod 调用 OLE 对象的方法
sp_OAGetProperty 取得 OLE 对象的属性值
sp_OASetProperty 将 OLE 对象属性设定为新值。
sp_OAGetErrorInfo 获得 OLE Automation 错误信息
sp_OAStop 停止整个服务器 OLE Automation 预存程序执行环境。
sp_OADestroy 销毁建立的 OLE 对象。
  知道了实现的可能性,那么到底该如何实现呢?下面请跟我来:
一、 其它编程语言建立Com程序(以Delphi为例)
1、 关闭所有项目,新建一个工程,将默认的单元文件unit1.pas保存为uMain.pas,将默认的工程文件project1保存为ptestCom。当然你也可以保存为你想要的文件名,但要记住这里设定的工程名就是后面需调用的com名称;
2、 点击菜单File->New->Other…,打开新建项目窗口,选择ActiveX页,在其中找到Automation Object(因为sql server中要求被它调用的OLE Automation Server须支持Idispatch接口,所以选择它),然后点OK,在弹出的响导框中输入Class Name(这里输入testObject),其它保持不变,按OK完成;
3、 在以上步骤完成后,就会弹出一个名叫testCom的类型库窗口,在窗口的左侧我们就会看到上面所创建的类testObject和一个叫ItestObject的接口类,选中ItestObject,点击工具栏上的New Method创建一个新的方法,命名为testfunc,然后在右边的parameters页上添加两个输入参数param1和param2(Type为BSTR,Modifier为[in])、一个输出参数paramout(Type为Variant *,Modifier为[out, retval]),Return type保持不变,为Hresult。点一下工具栏上的刷新按钮,按保存,将它保存为utestcom.pas和utestcom.tlb,然后关闭窗口;
4、 此时,在utestcom单元文件中你将会看到已经产生了一个函数:
function TtestObject.testfunc(const param1,param2: Widestring): OLEVariant;
begin
  end;
在其中加上如下代码(当然你可以在此函数中使用你自己的方法来实现):
Result := Param1 + Param2; //将传入两个字符串相加,然后返回
按保存,运行它,确认无误即可,如果有误,请检查以上步骤是否正确完成。
  二、在SQL Server中的调用
当创建好了Com程序并确定无误后,我们就可以用上面提到的几个相关系统存储过程来调用了,下面请看实例,具体说明已包含在代码中,不再重述。
  
create procedure Check_UserAthor --定义一个存储过程,接受两个参数
@c_id varchar(20),
@c_name varchar(20)
As
DECLARE @object int
Declare @Err int
Declare @return_value varchar(255)
Declare @src varchar(255), @desc varchar(255)

/**//*創建Com實例,调用如上创建的ptestcom.testobject*/
exec @err = master..sp_OACreate "ptestcom.testobject", @object out
  IF @err <> 0 /**//* 創建失敗*/
BEGIN

EXEC sp_OAGetErrorInfo @object, @src OUT, @desc OUT
SELECT hr=convert(varbinary(4),@err), Source=@src, Description=@desc
RETURN
END

/**//*調用如上声明的Com方法testfunc,@return_value为返回值,@c_id与@c_name为输入参数*/
EXEC @err = sp_OAMethod @object,'testfunc',@return_value OUT,@c_id,@c_name
IF @err <> 0
BEGIN
EXEC sp_OAGetErrorInfo @object, @src OUT, @desc OUT
SELECT hr=convert(varbinary(4),@err), Source=@src, Description=@desc
EXEC sp_OADestroy @object
RETURN
END

PRINT '返回結果為:' +(@return_value) --这里显示返回值

/**//*釋放Com實例*/
exec sp_OADestroy @object

GO
  三、调用

  如上存储过程创建无误后,我们就可以直接拿来调用了,在如上的示例中,如果我们输入'123','company',返回的结果就应该是123company这个字符串了。
  四、推论
以上的com程序其实适合于任何能与com进行通信的其它程序调用,比如在ASP中,也可以直接调用com组件,方法一样简单,不再详述,如有兴趣可与我探讨。

后记
以上示例有参考网上广为流传的一篇文章,不过那篇文章经转来转去,已被折磨得不成样子了。


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-295481-1-1.html 上篇帖子: VB.NET操作 SQL SERVER的 二进制数据 下篇帖子: SQL Server 2005分页的3中方法
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表