溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

怎么在Sql Server 數(shù)據(jù)庫(kù)中調(diào)用dll文件

發(fā)布時(shí)間:2021-05-31 16:56:25 來(lái)源:億速云 閱讀:242 作者:Leah 欄目:數(shù)據(jù)庫(kù)

怎么在Sql Server 數(shù)據(jù)庫(kù)中調(diào)用dll文件?相信很多沒(méi)有經(jīng)驗(yàn)的人對(duì)此束手無(wú)策,為此本文總結(jié)了問(wèn)題出現(xiàn)的原因和解決方法,通過(guò)這篇文章希望你能解決這個(gè)問(wèn)題。

1.首先新建一個(gè)空的解決方案,并添加一個(gè)類庫(kù),代碼如下,編譯并生產(chǎn)dll

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功能

默認(rèn)情況下,SQL Server中的CLR是關(guān)閉的,所以我們需要執(zhí)行如下命令打開(kāi)CLR:

 exec sp_configure 'clr enabled',1  
 reconfigure  
 Go

3.將程序集引用到數(shù)據(jù)庫(kù)中

CREATE ASSEMBLY testHelloWorld FROM 'C:\TEST.dll'   --('C:/TEST.dll'w為錯(cuò)誤寫(xiě)法)

4.創(chuàng)建函數(shù)

CREATE FUNCTION dbo.clrHelloWorld   
(   
  @name as nvarchar(200)   
)   
RETURNS nvarchar(200)  
 AS EXTERNAL NAME testHelloWorld.[TEST.TestTrans].GenerateDecryptString

5.調(diào)用函數(shù)

SELECT dbo.clrHelloWorld('耿耿')

6.執(zhí)行結(jié)果

HELLO WORLD  耿耿!

看完上述內(nèi)容,你們掌握怎么在Sql Server 數(shù)據(jù)庫(kù)中調(diào)用dll文件的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI