SQL Server居然也能调 C# 代码 ?

发布时间:2025-05-16 17:18:24 作者:益华网络 来源:undefined 浏览量(2) 点赞(3)
摘要:一:背景 1. 讲故事 前些天看到一个奇怪的 Function 函数,调用的是 C# 链接库中的一个 UserLogin 方法,参考代码如下: CREATE FUNCTION dbo.clr_UserLogin ( @name AS NVARCHAR(100), @password AS NVARCHAR(100) ) RETURNS INT

一:背景

1. 讲故事

前些天看到一个奇怪的 Function 函数,调用的是 C# 链接库中的一个 UserLogin 方法,参考代码如下:

CREATE FUNCTION dbo.clr_UserLogin

(

@name AS NVARCHAR(100),

@password AS NVARCHAR(100)

)

RETURNS INT

AS

EXTERNAL NAME asmXXX.[xxx.CLRFunctions].UserLogin;

GO

这就让我产生了很大的兴趣,众所周知 SQLSERVER 是 C++ 写的,那这里的 C++ 怎么和 C# 打通呢?而且 C# 是一门托管语言,需要 JIT 将其 native 化,这个 JIT 又在哪里呢?带着这些疑问一起研究下吧。

二:互通原理研究

1. 一个简单的例子

首先写一段简单的 C# 代码,然后把它编译成 dll。

namespace AQMN.Bussiness

{

public class UserFunctions

{

public static string UserLogin(string username, string password)

{

var random = new Random();

var isSuccess = random.Next() % 2 == 0;

return isSuccess ? "登录成功" : "登录失败";

}

}

}

接下来需要做的就是数据库参数配置,开启 CLR 支持,并且指定某个数据库支持 unsafe 模式。

EXEC sp_configure clr enabled, 1;

RECONFIGURE;

GO

ALTER DATABASE MyTestDB SET TRUSTWORTHY ON;

GO

为了能够调到 C# 的 UserLogin 方法,需要 SQLSERVER 先导入这个程序集,然后再以 Function 映射其中方法即可,参考代码如下:

CREATE ASSEMBLY clr_AQMN_Bussiness

FROM D:\net6\SQLCrawl\AQMN.Bussiness\bin\Debug\AQMN.Bussiness.dll

WITH PERMISSION_SET = UNSAFE;

GO

CREATE FUNCTION dbo.clr_UserLogin

(

@username AS NVARCHAR(100),

@password AS NVARCHAR(100)

)

RETURNS NVARCHAR(100)

AS

EXTERNAL NAME clr_AQMN_Bussiness.[AQMN.Bussiness.UserFunctions].UserLogin;

GO

创建完了之后,可以观察 assembly 开头的几个系统视图。

SELECT * FROM sys.assemblies

SELECT * FROM sys.assembly_files;

SELECT * FROM sys.assembly_modules;

看起来没啥问题,接下来调用一下刚才创建的 clr_UserLogin 函数。

SELECT dbo.clr_UserLogin(Njack,N123456) AS State

GO 10

从图中看登录结果是随机的,说明 C# 的 Random 函数起到了作用,非常有意思。

2. WinDbg 观察

从案例的运行结果看,推测在 SQLSERVER 中应该承载了一个 CLR 运行环境,那是不是这样呢?可以用 WinDbg 附加到 ​​sqlservr.exe​​ 进程,用 lm 观察下模块加载情况。

0:092> lm

start end module name

...

00007ff8`d3960000 00007ff8`d3aaf000 clrjit (deferred)

00007ff8`de040000 00007ff8`deb02000 clr (deferred)

...

0:092> !eeversion

4.8.4300.0 free

Server mode with 12 gc heaps

SOS Version: 4.8.4300.0 retail build

从输出看果然加载了 clr 和 clrjit 动态链接库,当前还是 gc server 模式,

二维码

扫一扫,关注我们

声明:本文由【益华网络】编辑上传发布,转载此文章须经作者同意,并请附上出处【益华网络】及本页链接。如内容、图片有任何版权问题,请联系我们进行处理。

感兴趣吗?

欢迎联系我们,我们愿意为您解答任何有关网站疑难问题!

您身边的【网站建设专家】

搜索千万次不如咨询1次

主营项目:网站建设,手机网站,响应式网站,SEO优化,小程序开发,公众号系统,软件开发等

立即咨询 15368564009
在线客服
嘿,我来帮您!