一、编写c#函数文件
1、新建一个类库文件
备注:sqlserver 2008只能用.net3.5版本。
2、如有想加入强命名的话可如下步骤:
参考博文:
1、运行在“开始菜单”-“程序”-“microsoft visual studio 2008”-“visual studio tools”-“visual studio 2008命令提示”(使用这一命令行工作才能能任意路径下执行vs命令行工具);
2、创建一个强名称程序集密钥文件文件
执行命令c:\sn -k keypair.snk
3、为类库绑定密钥文件
(1)a. 如果你有要引用的类库的源代码,可以在类库项目中的assemblyinfo.cs源文件中加入如下面的属性:
[assembly:assemblykeyfile(“c:\keypair.snk”)]
(如果有源代码的情况下,也可以直接使用项目配置来使类库项目直接生成并绑定密钥对。配置如:右击“类库项目”->“属性”->“签名”选项卡->选择“为程序集签名”复选框->“选择强名称密钥文件(k):”下拉框->“新建”或“浏览”选择一个已存在的密钥文件。)
b. 生成项目即可得到拥有强名称的类型库
(2)如果你只有第三方的类库(xxxxxx.dll)文件而没有源码项目的话,需要继续做如下操作。
a. 使用类库文件获取微软中间语言(msil)源码文件。
c:\>ildasm xxxxxx.dll /out:xxxxxx.il
b. 使用msil源码文件(xxxxxx.il)和新生成的(keypair.snk)密钥文件创建新的程序集类库文件
c:\>ilasm xxxxxx.il /dll /key=keypair.snk
二、数据库引入dll文件
备注:中间可能需要打开通道,百度很多方法。
create assembly api from 'd:\odoo\api\bin\debug\api.dll' with permission_set = unsafe go
三、创建函数
create function [dbo].[test]( ) returns [nvarchar] with execute as caller as external name [api].[api.class1].[test] go
四、调用函数
print dbo.test()