支援的 SQL Server CLR 裝載環境中未經測試的新版的.NET Framework 組件的原則

文章翻譯 文章翻譯
文章編號: 922672 - 檢視此文章適用的產品。
全部展開 | 全部摺疊

在此頁中

簡介

本文將告訴未經測試的 Microsoft.NET Framework 組件,在.NET Framework common language runtime (CLR) 的支援服務政策-裝載在 Microsoft SQL Server 中的環境。

其他相關資訊

測試的組件和支援

當您註冊組件參考 SQL Server 中未經測試的新版的.NET Framework 組件時,您可能會收到下列警告訊息:

警告: Microsoft.Net 架構組 'AssemblyName' 要註冊完全不會在裝載 SQL Server 環境中測試。

此訊息表示.NET Framework 組件在 SQL Server CLR 裝載環境中尚未經過測試。因此,組件不支援在 SQL Server CLR 裝載環境中。

未經測試的新版的.NET Framework 組件是重大狀況,例如記憶體不足的狀況發生時,可能會結束其主機處理程序。您可以使用 SQL Server CLR 裝載環境中的組件自行承擔風險。不過,Microsoft SQL Server 客戶支援服務 (CSS) 將無法幫助您使用,並不支援的.NET Framework 組件相關聯的問題進行疑難排解。如果 CSS 判斷特定不受支援的組件會導致 SQL Server 的問題,您可能會要求您停止使用組件。此外,您可能需要停止使用 CSS 疑難排解特定的 SQL Server 的問題,如有必要時,暫時的組件。

組件登錄

有兩種類型的.NET 組件: 純粹的和混合。純粹的.NET 組件包含僅 MSIL 指令。混合組件同時包含不受管理的機器指令和 MSIL 指令。混合組件在一般情況下編譯,在 c + + 編譯器中使用 「 clr 」 參數,而且也包含透過原生 c + + 程式碼所建立的機器指令。

當您使用.NET Framework 組件不在支援的清單中時,您必須要註冊組件和參考的組件,SQL Server 資料庫中時,用以建立組件的陳述式。SQL Server 建立組件的陳述式可讓只有純粹組.NET Framework 件註冊。如果組件或任何參考組件不是單純的.NET Framework 組件 (而且,因此,就是混合的組件),您會收到下列錯誤訊息:

訊息 6544,層次 16,狀態 1,行 2

建立組件的組件 '<assembly name="">' 失敗,因為組件 '<assembly name="">' 的格式不正確或不單純的.NET 組件。</assembly> </assembly>

無法驗證的 PE 標頭原生虛設常式。

如此一來,您無法使用.NET Framework 組件,以及 SQL CLR,除非組件是在支援此文件中的清單中。此外,.NET Framework 組件可以從純粹組件變更為不同版本之間的混合組件。如果您使用的組件,並不支援的清單中,您可能必須在.NET Framework 的一種版本,但在另一個,組件的運作的情況。這項限制不適用於支援的清單中的組件,因為這些組件並不需要使用建立組件的陳述式來註冊。

此外,您必須在升級 Microsoft.NET Framework 之後,維護這些組件。如需詳細資訊,按一下下列文章編號,以返回文件的 「 Microsoft 知識庫 」 中的文件:
949080 當您執行 CLR 常式,或用於 SQL Server 中的組件時,出現錯誤訊息: 「 主機存放區中的組件具有不同的簽章,比組件在 GAC 中。(從 HRESULT 的例外狀況: 0x80131050)"

在 SQL Server CLR 裝載環境所支援的組件

在 SQL Server CLR 裝載環境中支援下列的.NET Framework 組件:
  • Microsoft.VisualBasic.dll
  • Mscorlib.dll
  • System.Data.dll
  • System.dll
  • System.Xml.dll
  • Microsoft.VisualC.dll
  • CustomMarshalers.dll
  • System.Security.dll
  • System.Web.Services.dll
  • System.Data.SqlXml.dll
  • System.Transactions.dll
  • System.Data.OracleClient.dll
  • System.Configuration.dll

屬性

文章編號: 922672 - 上次校閱: 2013年3月8日 - 版次: 3.0
這篇文章中的資訊適用於:
  • Microsoft SQL Server 2012 Enterprise
  • Microsoft SQL Server 2012 Standard
  • Microsoft SQL Server 2012 Developer
  • Microsoft SQL Server 2012 Express
  • Microsoft SQL Server 2008 R2 Developer
  • Microsoft SQL Server 2008 R2 Enterprise
  • Microsoft SQL Server 2008 R2 Express
  • Microsoft SQL Server 2008 R2 Express with Advanced Services
  • Microsoft SQL Server 2008 R2 Standard
  • Microsoft SQL Server 2008 R2 Web
  • Microsoft SQL Server 2008 R2 Workgroup
  • Microsoft SQL Server 2008 Developer
  • Microsoft SQL Server 2008 Enterprise
  • Microsoft SQL Server 2008 Express
  • Microsoft SQL Server 2008 Standard
  • Microsoft SQL Server 2008 Web
  • Microsoft SQL Server 2008 Workgroup
  • Microsoft SQL Server 2005 Standard Edition
  • Microsoft SQL Server 2005 Enterprise Edition
  • Microsoft SQL Server 2005 Developer Edition
  • Microsoft SQL Server 2005 Express Edition
  • Microsoft SQL Server 2005 Express Edition with Advanced Services
  • Microsoft SQL Server 2005 Workgroup Edition
  • Microsoft SQL Server 2005 Compact Edition
關鍵字:?
kbhowto kbexpertiseadvanced kbsql2005clr kbinfo kbmt KB922672 KbMtzh
機器翻譯
重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。
按一下這裡查看此文章的英文版本:922672
Microsoft及(或)其供應商不就任何在本伺服器上發表的文字資料及其相關圖表資訊的恰當性作任何承諾。所有文字資料及其相關圖表均以「現狀」供應,不負任何擔保責任。Microsoft及(或)其供應商謹此聲明,不負任何對與此資訊有關之擔保責任,包括關於適售性、適用於某一特定用途、權利或不侵權的明示或默示擔保責任。Microsoft及(或)其供應商無論如何不對因或與使用本伺服器上資訊或與資訊的實行有關而引起的契約、過失或其他侵權行為之訴訟中的特別的、間接的、衍生性的損害或任何因使用而喪失所導致的之損害、資料或利潤負任何責任。

提供意見

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com