全国统一热线:
028-86758058
18980748058
购买流程
付款方式
常见问题
在线提问
续租服务
购物车(
0
件)
用户名:
密 码:
记住
首 页
HOME
域名注册
DOMAIN
虚拟主机
WEB HOST
成品网站超市
AUTO Site
VPS主机
VPS SERVER
云 主 机
CLOUD HOST
租用托管
SERVER
海外主机
HK HOST
代理专区
AGENT
客服中心
SERVICE
站长教程
SERVICE
欢迎光临西部数据云计算中心,我们将竭诚为您提供最优质的服务!
中文域名
域名转入
域名转出
DNS管理
动态域名
获取域名证书
域名停放
域名过户
集群主机
双线主机
基本主机
港台主机
论坛主机
Linux主机
Vip合租主机
超G型主机
ASP.net主机
Java主机
智能建站主机
网店主机
美国主机
数据库
成品网站超市
智能建站主机
集群VPS主机
国内VPS主机
香港VPS主机
美国VPS主机
云主机介绍
云主机购买
服务器租用
主机托管
常见问题
香港主机
港台主机
美国主机
国内免备案
步骤流程
代理级别
代理合同
代理模式
代理优势
在线申请
产品列表
常见问题
代理商分布图
常见问题
有问必答
跟踪提问
购买流程
产品价格
付款方式
常用软件
网站备案
续租服务
汇款确认
相关文档
联系我们
域名资讯
主机资讯
行业动态
网页制作
php教程
mysql教程
域名资讯
云计算资讯
网络编程
您当前的位置:
首页
>
网络编程
>
Net教程
mssql 存储过程调用C#编写的DLL文件
时间:2015-01-29 来源:互联网 作者:佚名
网上很有多类似的文章,但描述不完整,在某些关键的地方,少了相应的补充,以至于那些例子都无法测试通过。
我把其中的一种思路整理出来:
1. 准备DLL文件
首先,你需要新建一个类库工程,工程名没有要求,随意取为Test。新建一个类文件,例如:
复制代码
代码如下:
using System;
namespace Test
{
public class SayHello
{
public SayHello()
{
}
public string Hi()
{
return "Hello!";
}
public string Hey(string name)
{
return "Hey!" + name;
}
}
}
编译类库工程得到DLL文件。
2. 注册DLL
将DLL文件拷贝到
数据库
服务器
,例如:将Test.dll拷贝到D盘,命令提示窗口中,进入到.net framework 1.1的目录下,c:\windows\Microsoft.NET\Framework\v1.1.4322>,使用命令:
regasm d:\Test.dll /codebase
窗口提示: 成功注册了类型(或Types registered successfully)
则说明注册成功。
3. 测试脚本
复制代码
代码如下:
DECLARE @object int
DECLARE @hr int
DECLARE @property varchar(255)
DECLARE @return varchar(255)
DECLARE @src varchar(255), @desc varchar(255)
-- 创建对象实例, sp_OACreate 后引号内为'命名空间.类名'
EXEC @hr = sp_OACreate 'Test.SayHello', @object OUT
IF @hr <> 0
BEGIN
goto info
END
-- 调用对象方法, sp_OAMetohd 参数为方法名,要求该方法属于公共类型(public),且不能是静态方法(即被static修饰)
EXEC @hr = sp_OAMethod @object, 'Hi', @return OUT
-- EXEC @hr = sp_OAMethod @object, 'Hey', @return OUT, 'Baby' -- 带参数的方法的调用,多个参数,依次累加在后
IF @hr <> 0
BEGIN
goto info
END
-- 查看结果
print @return
EXEC @hr = sp_OADestroy @object
IF @hr <> 0
BEGIN
goto info
END
--info:
EXEC sp_OAGetErrorInfo @object, @src OUT, @desc OUT
SELECT hr=convert(varbinary(4),@hr), Source=@src, Description=@desc
4. 补充说明
以上步骤,在sql server 2000下测试通过,不支持其他关系数据库。
sql server 2005中可以使用“CLR函数”来达到上述效果,图形化操作,非常简便,不得不说微软的产品容易让人产生依赖感。
来顶一下
返回首页
推荐资讯
.NET 动态编译
这在很大程度上给我们提供了另外一种扩展的方式(当然这并不
C# 动态编译、动态执行、动态调试
在此基础上我做了一些封装,为使调用更加简单,并增加了对动
相关文章
C# 调用存储过程简单完整的实例代码
asp.net 存储过程调用
asp.net安全、实用、简单的大容量存储过程分页第1/2页
asp.net结合aspnetpager使用SQL2005的存储过程分页
asp.net网站开发包wq.dll打包下载
ajaxpro.dll 控件实现异步刷新页面
asp.net sql存储过程
手动把asp.net的类生成dll文件的方法
asp.net 数据访问层 存储过程分页语句
asp.net 安全、实用、简单的大容量存储过程分页第1/2页
栏目更新
栏目热门
返回首页
关于我们
联系我们
付款方式
价格总览
资讯中心
友情链接
媒体关注
有问必答
投诉建议
网站备案
《中华人民共和国增值电信业务经营许可证》编号:川B2-20080058号
官方网址:
xibushuju.com
西部数据
Copyright © 2002~2015
天府快车
版权所有
电话总机:
028-86758058
(50线) 传真:
028-86758058