gpt4 book ai didi

ef-code-first - 新的嵌入式 Firebird,代码优先,EF6 项目导致 SerializationException

转载 作者:行者123 更新时间:2023-12-04 07:36:43 28 4
gpt4 key购买 nike

我正在尝试将带有 EF6 的 Firebird 设置为我正在编写的一个简单应用程序的嵌入式服务器,但未能使其正常工作。我有一个 CLI 项目,它是应用程序,DAL 项目是 DB。我向两者添加了 NuGet 包,并创建了一个带有简单实体的 DbContext,并成功创建了初始迁移,但是在尝试运行时 update-database要执行迁移,我在包管理器控制台中收到此错误:

System.Runtime.Serialization.SerializationException: Type is not resolved for member 'FirebirdSql.Data.FirebirdClient.FbException,FirebirdSql.Data.FirebirdClient, Version=4.10.0.0, Culture=neutral, PublicKeyToken=3750abcc3150b00c'.
at System.AppDomain.DoCallBack(CrossAppDomainDelegate callBackDelegate)
at System.Data.Entity.Migrations.Design.ToolingFacade.Run(BaseRunner runner)
at System.Data.Entity.Migrations.Design.ToolingFacade.Update(String targetMigration, Boolean force)
at System.Data.Entity.Migrations.UpdateDatabaseCommand.<>c__DisplayClass2.<.ctor>b__0()
at System.Data.Entity.Migrations.MigrationsDomainCommand.Execute(Action command)
Type is not resolved for member 'FirebirdSql.Data.FirebirdClient.FbException,FirebirdSql.Data.FirebirdClient, Version=4.10.0.0, Culture=neutral, PublicKeyToken=3750abcc3150b00c'.

实际上我只是注意到现在没有任何效果...如果我删除我的迁移并尝试重新创建它,我会收到此错误。我以前能够启用迁移并创建一个,但现在我不能。奇怪。

我所有的项目都针对 .NET 4.5.2,并且它们都具有相同的包版本。我的解决方案/项目路径中没有空格、与号或奇怪的字符。我试过使用我的应用程序项目作为启动项目和 DAL 项目,但没有任何区别。

我的 packages.config :
<?xml version="1.0" encoding="utf-8"?>
<packages>
<package id="EntityFramework" version="6.1.3" targetFramework="net452" />
<package id="EntityFramework.Firebird" version="4.10.0.0" targetFramework="net452" />
<package id="FirebirdSql.Data.FirebirdClient" version="4.10.0.0" targetFramework="net452" />
</packages>

我的 App.config :
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<configSections>
<section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
<!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->
</configSections>
<connectionStrings>
<add name="DAL.DbContext" providerName="FirebirdSql.Data.FirebirdClient" connectionString="User=SYSDBA;Password=masterkey;Database=SampleDatabase.fdb;DataSource=localhost;Port=3050;Dialect=3;Charset=NONE;Role=;Connection lifetime=15;Pooling=true;MinPoolSize=0;MaxPoolSize=50;Packet Size=8192;ServerType=1;" />
</connectionStrings>
<entityFramework>
<defaultConnectionFactory type="FirebirdSql.Data.EntityFramework6.FbConnectionFactory, EntityFramework.Firebird" />
<providers>
<!--<provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />-->
<provider invariantName="FirebirdSql.Data.FirebirdClient" type="FirebirdSql.Data.EntityFramework6.FbProviderServices, EntityFramework.Firebird" />
</providers>
</entityFramework>
<runtime>
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
<dependentAssembly>
<assemblyIdentity name="FirebirdSql.Data.FirebirdClient" publicKeyToken="3750abcc3150b00c" culture="neutral" />
<bindingRedirect oldVersion="0.0.0.0-4.5.0.0" newVersion="4.5.0.0" />
</dependentAssembly>
</assemblyBinding>
</runtime>
<startup>
<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5.2" />
</startup>
<system.data>
<DbProviderFactories>
<remove invariant="FirebirdSql.Data.FirebirdClient" />
<add name="FirebirdClient Data Provider" invariant="FirebirdSql.Data.FirebirdClient" description=".NET Framework Data Provider for Firebird" type="FirebirdSql.Data.FirebirdClient.FirebirdClientFactory, FirebirdSql.Data.FirebirdClient" />
</DbProviderFactories>
</system.data>
</configuration>

我刚刚在网上找到的连接字符串可能是错误的,但我找不到任何文档......

我以前用 SqlServer 做过几十次代码优先的 EF,以前从来没有遇到过这个问题,但这个应用程序不会有一个真正的服务器可以运行。不幸的是,这似乎是一个比 Firebird 或 EF 更普遍的问题,但我不知道从哪里看这一点。

最佳答案

我有同样的确切问题,并且能够在上一个答案的帮助下确切地弄清楚发生了什么。这是一个已知的错误,他们修复了 6.2。异常(exception)是隐藏了一个更深层次的问题,如果没有适当的堆栈跟踪可能很难知道。一种解决方法是将您的 Entity Framework 升级到最新的 6.2 预发布版本,然后查看真正的问题是什么,然后恢复到您当前的版本,在我的情况下是 6.1.3

  • 从 Entity Framework 6.2 获取最新的签名版本。您将需要添加 NuGet 存储库 https://www.myget.org/F/aspnetwebstacknightly/ .此步骤的详细说明可在此处找到:https://github.com/aspnet/EntityFramework6/wiki/Nightly-Builds
  • 打开解决方案的 NuGet 包管理器
  • 选中 NuGet 包管理器顶部的“预发布”复选框
  • 在项目选择窗口中选择所有引用 Entity Framework 的项目
  • 在版本下拉列表中选择最新的 6.2 版本并单击“安装”按钮。这将卸载您当前的版本并安装所选的预发布版本
  • 构建您的解决方案
  • 打开包管理器控制台并输入命令 Update-Database

  • 此时,您应该会看到一条详细的错误消息,说明出了什么问题,它应该让您更好地了解解决问题所需的操作。就我而言,访问文件时出现问题,需要以管理员身份运行 Visual Studio。

    解决问题后,您可以撤消对 Entity Framework 版本的更改,也可以按照上述步骤操作,但将版本更新为您使用的先前版本。

    关于ef-code-first - 新的嵌入式 Firebird,代码优先,EF6 项目导致 SerializationException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34959584/

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