支持的 .NET Framework 库

适用范围:SQL Server

使用 SQL Server 中托管的公共语言运行时(CLR),可以在托管代码中创作存储过程、触发器、用户定义函数、用户定义的类型和用户定义的聚合。 使用 .NET Framework 类库中的功能,可以访问预生成的类,这些类提供字符串操作、高级数学操作、文件访问、加密等功能。 可通过任何托管存储过程、用户定义类型、触发器、用户定义函数或用户定义聚合访问这些类。

如果在全局程序集缓存(GAC)中服务或升级不支持的程序集,SQL Server 应用程序可以停止工作。 这是因为 GAC 中的维护或升级库不会更新 SQL Server 中的这些程序集。 如果程序集同时存在于 SQL Server 数据库和 GAC 中,则程序集的两个副本必须完全匹配。 如果它们不匹配,则 SQL Server CLR 集成使用程序集时发生错误。 如果在数据库中注册的 GAC 中服务或升级任何程序集(包括不支持的 .NET Framework 程序集),请确保使用 ALTER ASSEMBLY 语句服务或升级 SQL Server 数据库中程序集的副本。 有关详细信息,请参阅 MSSQLSERVER_6522

支持的库

SQL Server 包含受测试的受支持 .NET Framework 库的列表,以确保它们符合与 SQL Server 交互的可靠性和安全标准。 在代码中使用支持库之前,无需在服务器上显式注册它们;SQL Server 直接从全局程序集缓存(GAC)加载它们。

SQL Server 中的 CLR 集成支持的库/命名空间包括:

  • mscorlib.dll
  • CustomMarshalers.dll
  • Microsoft.VisualBasic.dll
  • Microsoft.VisualC.dll
  • System.Configuration.dll
  • System.Core.dll
  • System.Data.OracleClient.dll
  • System.Data.SqlXml.dll
  • System.Data.dll
  • System.Deployment.dll
  • System.Security.dll
  • System.Transactions.dll
  • System.Web.Services.dll
  • System.Xml.Linq.dll
  • system.Xml.dll
  • System.dll

不支持的库

通过托管存储过程、触发器、用户定义函数、用户定义类型和用户定义聚合仍可以调用不支持的库。 必须先使用 CREATE ASSEMBLY 语句在 SQL Server 数据库中注册不支持的库,然后才能在代码中使用。 对于在服务器上注册和运行的任何不支持的库,应检查和测试其安全性和可靠性。

例如,不支持 System.DirectoryServices 命名空间。 必须先向 UNSAFE 权限注册 System.DirectoryServices.dll 程序集,然后才能从代码调用它。 UNSAFE 权限是必需的,因为 System.DirectoryServices 命名空间中的类不符合 SAFEEXTERNAL_ACCESS的要求。 有关详细信息,请参阅 CLR 集成编程模型限制CLR 集成代码访问安全性