服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Sql Server - Sql Server 数据库中调用dll文件的过程

Sql Server 数据库中调用dll文件的过程

2020-05-26 15:12Andrewniu Sql Server

这篇文章主要介绍了Sql Server 数据库中调用dll文件的过程,非常不错,具有一定的参考借鉴价值,感兴趣的朋友跟随脚本之家小编一起学习吧

1.首先新建一个空的解决方案,并添加一个类库,代码如下,编译并生产dll

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
using System;
using System.Collections.Generic;
using System.Data.SqlTypes;
using System.Linq;
using System.Text;
namespace TEST
{
  public class TestTrans
  {
    [Microsoft.SqlServer.Server.SqlFunction]
    public static SqlString GenerateDecryptString(string name)
    {
      string decode = string.Empty;
      decode = string.Format("HELLO WORLD {0}!", name);//DecryptString(dataXML.Value);
      SqlString sqlValue = new SqlString(decode);
      return sqlValue;
    }
  }
}

2.启用CLR功能

默认情况下,SQL Server中的CLR是关闭的,所以我们需要执行如下命令打开CLR:

?
1
2
3
exec sp_configure 'clr enabled',1 
reconfigure 
Go

3.将程序集引用到数据库中

?
1
CREATE ASSEMBLY testHelloWorld FROM 'C:\TEST.dll'   --('C:/TEST.dll'w为错误写法)

4.创建函数

?
1
2
3
4
5
6
CREATE FUNCTION dbo.clrHelloWorld  
(  
  @name as nvarchar(200)  
)  
RETURNS nvarchar(200) 
 AS EXTERNAL NAME testHelloWorld.[TEST.TestTrans].GenerateDecryptString

5.调用函数

?
1
SELECT dbo.clrHelloWorld('耿耿')

6.执行结果

HELLO WORLD  耿耿!

总结

以上所述是小编给大家介绍的Sql Server 数据库中调用dll文件的过程,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!

原文链接:https://blog.csdn.net/andrewniu/article/details/80345926

延伸 · 阅读

精彩推荐