1、编写C#函数文件sql
一、新建一个类库文件数据库
备注:sqlserver 2008只能用.net3.5版本。api
二、若有想加入强命名的话可以下步骤:函数
参考博文:https://blog.csdn.net/donnie88888888/article/details/52743064工具
一、运行在“开始菜单”-“程序”-“Microsoft Visual Studio 2008”-“Visual Studio Tools”-“Visual Studio 2008命令提示”(使用这一命令行工做才能能任意路径下执行VS命令行工具);sqlserver
二、建立一个强名称程序集密钥文件文件spa
执行命令C:\sn -k keypair.snk.net
三、为类库绑定密钥文件命令行
(1)a. 若是你有要引用的类库的源代码,能够在类库项目中的AssemblyInfo.cs源文件中加入以下面的属性:
[assembly:AssemblyKeyFile("C:\keypair.snk")]3d
(若是有源代码的状况下,也能够直接使用项目配置来使类库项目直接生成并绑定密钥对。配置如:右击“类库项目”->“属性”->“签名”选项卡->选择“为程序集签名”复选框->“选择强名称密钥文件(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
2、数据库引入dll文件
备注:中间可能须要打开通道,百度不少方法。
create assembly api from 'D:\Odoo\api\bin\Debug\api.dll' with permission_set = UNSAFE go
3、建立函数
create FUNCTION [dbo].[test]( ) RETURNS [nvarchar] WITH EXECUTE AS CALLER AS EXTERNAL NAME [api].[api.Class1].[test] GO
4、调用函数
print dbo.test()