gpt4 book ai didi

c# - 在 SQL CLR 中使用 Entity Framework 6/EF Core

转载 作者:行者123 更新时间:2023-11-30 22:53:52 26 4
gpt4 key购买 nike

Microsoft Azure 技术支持已确认 SQL Server 托管实例 CLR 支持所有版本的 .Net 4.XX,包括 4.7.2

我们正在使用 4.7.2 和最新的 EF 6.2 转换业务层的某些部分

Use Entity Framework in CLR Stored procedure

https://patrickdesjardins.com/blog/how-to-use-third-party-dll-reference-in-a-sql-clr-function

因此,为了利用对经过良好测试的代码的现有投资,我们希望将某些业务层移至数据库中。

但是我们在发布时遇到了问题。

Creating [System.Dynamic]...

Warning: The Microsoft .NET Framework assembly 'system.dynamic, version=4.0.0.0, culture=neutral, publickeytoken=b03f5f7f11d50a3a.'

您正在注册未在 SQL Server 托管环境中进行全面测试,因此不受支持。将来,如果升级或维护此程序集或 .NET Framework,您的 CLR 集成例程可能会停止工作。有关详细信息,请参阅 SQL Server 联机丛书。

(47,1):SQL72014:.Net SqlClient 数据提供程序:

消息 6218,级别 16,状态 2,第 1 行
为程序集“System.Dynamic”创建程序集失败,因为程序集“System.Dynamic”验证失败。检查引用的程序集是否是最新的和可信的(对于 external_access 或不安全的)在数据库。
CLR 验证程序错误消息(如果有)将跟随此消息 [ :
System.Dynamic.ArgBuilder::MarshalToRef][mdToken=0x6000002][offset 0x00000000] 代码大小为零。 [: System.Dynamic.ArgBuilder::UnmarshalFromRef][mdToken=0x6000003][偏移量

附言(恕我直言,EF 核心是否也无所谓,尽管我们正在尝试使用 EF6.2)

编辑:已对我所指的所有程序集授予 UNSAFE 权限:以下是所有依赖项:

enter image description here

<ItemGroup>
<Reference Include="Microsoft.CSharp">
<HintPath>..\packages2019\dotnet 4.7.2\Microsoft.CSharp.dll</HintPath>
<SqlPermissionSet>UNSAFE</SqlPermissionSet>
<GenerateSqlClrDdl>True</GenerateSqlClrDdl>
<IsModelAware>True</IsModelAware>
<SpecificVersion>True</SpecificVersion>
</Reference>
<Reference Include="System.Dynamic">
<HintPath>..\packages2019\dotnet 4.7.2\System.Dynamic.dll</HintPath>
<SqlPermissionSet>UNSAFE</SqlPermissionSet>
<GenerateSqlClrDdl>True</GenerateSqlClrDdl>
<IsModelAware>True</IsModelAware>
<SpecificVersion>True</SpecificVersion>
</Reference>
<Reference Include="System.Runtime.Serialization">
<HintPath>..\packages2019\dotnet 4.7.2\System.Runtime.Serialization.dll</HintPath>
<SqlPermissionSet>UNSAFE</SqlPermissionSet>
<GenerateSqlClrDdl>True</GenerateSqlClrDdl>
<IsModelAware>True</IsModelAware>
<SpecificVersion>True</SpecificVersion>
</Reference>
<Reference Include="SMDiagnostics">
<HintPath>..\packages2019\v4.0.30319\SMDiagnostics.dll</HintPath>
<SqlPermissionSet>UNSAFE</SqlPermissionSet>
<GenerateSqlClrDdl>True</GenerateSqlClrDdl>
<IsModelAware>True</IsModelAware>
<SpecificVersion>True</SpecificVersion>
</Reference>
<Reference Include="System.ServiceModel.Internals">
<HintPath>..\packages2019\v4.0.30319\System.ServiceModel.Internals.dll</HintPath>
<SqlPermissionSet>UNSAFE</SqlPermissionSet>
<GenerateSqlClrDdl>True</GenerateSqlClrDdl>
<IsModelAware>True</IsModelAware>
<SpecificVersion>True</SpecificVersion>
</Reference>
<Reference Include="EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089, processorArchitecture=MSIL">
<HintPath>..\packages\EntityFramework.6.2.0\lib\net45\EntityFramework.dll</HintPath>
<SqlPermissionSet>UNSAFE</SqlPermissionSet>
<SpecificVersion>True</SpecificVersion>
<IsModelAware>True</IsModelAware>
<GenerateSqlClrDdl>True</GenerateSqlClrDdl>
</Reference>
<Reference Include="EntityFramework.SqlServer, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089, processorArchitecture=MSIL">
<HintPath>..\packages\EntityFramework.6.2.0\lib\net45\EntityFramework.SqlServer.dll</HintPath>
<SqlPermissionSet>UNSAFE</SqlPermissionSet>
<SpecificVersion>True</SpecificVersion>
<IsModelAware>True</IsModelAware>
<GenerateSqlClrDdl>True</GenerateSqlClrDdl>
</Reference>

编辑 3:Azure SQL Server MI 中的不安全代码 enter image description here

编辑 4:

  • 显示停止器是:System.RunTime.Serialization,
CREATE ASSEMBLY [System.Runtime.Serialization]
AUTHORIZATION [dbo]
FROM 0x4D5...
WITH PERMISSION_SET = UNSAFE;

这会阻止我将 Entity Framework UNSAFE 程序集创建到数据库中。我们可以通过 system.Runtime.Serialization 吗?

GO
CREATE ASSEMBLY [EntityFramework]
AUTHORIZATION [dbo]
FROM 0x4D5A90...
WITH PERMISSION_SET = UNSAFE;


GO
PRINT N'Creating [EntityFramework.SqlServer]...';


GO
CREATE ASSEMBLY [EntityFramework.SqlServer]
AUTHORIZATION [dbo]
FROM 0x4...
WITH PERMISSION_SET = UNSAFE;

Warning: The Microsoft .NET Framework assembly 'system.runtime.serialization, version=4.0.0.0, culture=neutral, publickeytoken=b77a5c561934e089.' you are registering is not fully tested in the SQL Server hosted environment and is not supported. In the future, if you upgrade or service this assembly or the .NET Framework, your CLR integration routine may stop working. Please refer SQL Server Books Online for more details. Msg 6218, Level 16, State 2, Line 11 CREATE ASSEMBLY for assembly 'System.Runtime.Serialization' failed because assembly 'System.Runtime.Serialization' failed verification. Check if the referenced assemblies are up-to-date and trusted (for external_access or unsafe) to execute in the database. CLR Verifier error messages if any will follow this message [ : System.AppContextDefaultValues::PopulateDefaultValues][mdToken=0x6000001] [offset 0x00000000] Code size is zero.

最佳答案

SQL Server 的 CLR 主机将使用系统上安装的最高版本的 .NET Framework,作为它链接到的 CLR 版本。 SQL Server 2005 - 2008 R2 链接到 CLR 2.0 版,因此它们将使用 .NET Framework 2.0、3.0 和 3.5 版。 SQL Server 2012 及更新版本都链接到 CLR 4.0 版,因此将使用 .NET Framework 4.x 版。

也就是说,有些Framework库是内置的,不需要手动添加。这些列在这里:

Supported .NET Framework Libraries

如果您需要的库不在该列表中,您可以自己添加,但是这并不意味着您可以添加任何库。 SQL Server 只允许纯 MSIL 库,不允许混合模式(混合 = 包含托管和非托管代码)。如果您需要一个混合模式的库,那么您无法将其加载到 SQL Server 中。另外,请记住,即使现在的库是纯 MSIL,也不意味着它不能在未来的框架更新中转换为混合模式(是的,这已经发生了)。

考虑到所有这些,错误消息中的以下项目:

Code size is zero.

可能表示您正在尝试加载引用库。您需要加载实际 库,而不是它的引用版本。

我在 SQL Server 2017 上尝试了以下操作,并且能够全部加载它们,但并非所有都需要显式加载。有些自动加载其他的,因为它们在同一个文件夹中:

CREATE ASSEMBLY [Microsoft.CSharp]
FROM 'C:\Windows\Microsoft.NET\Framework64\v4.0.30319\Microsoft.CSharp.dll'
WITH PERMISSION_SET = UNSAFE;
-- includes System.Dynamic


CREATE ASSEMBLY [System.Runtime.Serialization]
FROM 'C:\Windows\Microsoft.NET\Framework64\v4.0.30319\System.Runtime.Serialization.dll'
WITH PERMISSION_SET = UNSAFE;
-- includes SMDiagnostics, System.ServiceModel.Internals

然后检查:

SELECT * FROM sys.assemblies;
/*
Microsoft.CSharp
System.Dynamic
System.Runtime.Serialization
System.ServiceModel.Internals
SMDiagnostics
*/

请注意,目前,我将数据库设置为 TRUSTWORTHY ON。这不是我通常推荐的东西,也可能不是必需的,但在我完成处理如何正确和轻松地处理这个问题的帖子之前,TRUSTWORTHY 就足够了。

我没有要加载的 EntityFramework 库,但您遇到的错误是第一个,而我在上面发布的语句没有出现该错误。如果您能够执行这 2 个语句以加载所有 5 个库,然后在 EntityFramework 上出现错误,那么我们将查看具体的错误消息。

但是,即使您能够加载所有这些 DLL,包括 EntityFramework 的两个 DLL,也不能保证您实际上能够使用 EF。 EF 可能无法在 SQLCLR 中运行。我不记得具体的 EF,但我确实知道 SMO,例如,包含检测它是否在 SQL Server 中运行的代码,如果是,那么它会引发一个异常,说明它不允许运行在 SQL Server 中。

关于c# - 在 SQL CLR 中使用 Entity Framework 6/EF Core,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56823569/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com