SqlClr中如何引用更多的dll

新建一个 SqlClr 项目:



但是引用DLL 时, 你会发现, 可以引用的DLL 是如此之少……


但不要慌张, 按下面来做就可以了……

--如果存在 System.Management 则删除
IF EXISTS(SELECT * FROM SYS.ASSEMBLIES WHERE NAME='System.Management') 
	DROP  ASSEMBLY [System.Management]
GO
CREATE ASSEMBLY [System.Management] FROM 'C:\Windows\Microsoft.NET\Framework\v2.0.50727\System.Management.dll' WITH PERMISSION_SET = UNSAFE;
GO

注: SqlClr 项目是以特定的数据库为基准的, 必须将 dll 附加到相应在的库上, 即使非直接引用的dll, 也必须附加上去。



很抱歉,MSSQL2008R2本身不支持发送HTTP请求的功能,因此不能通过存储过程直接发送GET请求。你可以考虑使用SQLCLR(即SQL Server Common Language Runtime)来实现发送HTTP请求的功能,步骤如下: 1. 创建一个C#类库项目,编写一个类来实现发送HTTP请求的功能。 2. 在该类库项目添加对System.Net命名空间的引用。 3. 在类编写发送HTTP请求的代码,例如使用HttpWebRequest类来发送请求。 4. 将该类库项目编译为DLL文件。 5. 将该DLL文件上传到MSSQL2008R2数据库服务器上。 6. 在MSSQL2008R2数据库创建一个SQLCLR存储过程,以调用该DLL文件的类和方法来发送HTTP请求。 以下是一个简单的示例代码,仅供参考: ``` using System; using System.Data; using System.Data.SqlClient; using System.Data.SqlTypes; using Microsoft.SqlServer.Server; using System.Net; public partial class StoredProcedures { [Microsoft.SqlServer.Server.SqlProcedure] public static void SendHttpRequest(SqlString url) { try { HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url.ToString()); request.Method = "GET"; HttpWebResponse response = (HttpWebResponse)request.GetResponse(); response.Close(); } catch (Exception ex) { SqlContext.Pipe.Send(ex.Message); } } } ``` 在此示例,我们创建了一个名为SendHttpRequest的SQLCLR存储过程,该存储过程接受一个名为url的输入参数,该参数为SqlString类型,表示要发送的HTTP请求的URL。 在存储过程,我们使用HttpWebRequest类来创建HTTP请求对象,并设置请求的方法为GET。然后,我们发送请求并获取响应,最后关闭响应流。如果发送HTTP请求发生错误,则将错误消息发送回客户端。 请注意,在使用SQLCLR存储过程时,需要启用CLR集成功能。您可以在MSSQL2008R2数据库使用以下命令启用CLR集成功能: ``` sp_configure 'clr enabled', 1; RECONFIGURE; ``` 启用CLR集成功能后,您可以创建SQLCLR存储过程并调用它,以实现发送HTTP请求的功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值