'System.Data.Entity.Migrations.DbMigrationsConfiguration`1'的类型初始值设定项引发了异常

Kgn*_*web 5 c# mysql asp.net asp.net-mvc entity-framework

我有ASP.Net MVC网站。

技术栈

  • ASP.Net 4.6
  • C#.Net
  • EF 6
  • MySQL数据库

当我尝试使用Nuget命令生成数据库时:

Enable-Migrations -force
Run Code Online (Sandbox Code Playgroud)

我收到以下异常

'System.Data.Entity.Migrations.DbMigrationsConfiguration'1'的类型初始值设定项引发了异常。

我已对以下内容进行了交叉检查和尝试:-

我的App.Config:-

 <connectionStrings>
<add name="mydbContext" providerName="MySql.Data.MySqlClient" connectionString="Server=localhost;port=8080;database=mydb;uid=root;password=" />
</connectionStrings>



<entityFramework>
<defaultConnectionFactory type="MySql.Data.Entity.MySqlConnectionFactory,   MySql.Data.Entity.EF6" />
<providers>
  <provider invariantName="MySql.Data.MySqlClient" type="MySql.Data.MySqlClient.MySqlProviderServices, MySql.Data.Entity.EF6, Version=6.8.8.0, Culture=neutral, PublicKeyToken=c5687fc88969c44d"></provider>
</providers>
Run Code Online (Sandbox Code Playgroud)

小智 6

通过使configSections成为配置文件中配置的第一个子项来修复它。

<configuration> 
Run Code Online (Sandbox Code Playgroud)

……


小智 6

如果没有添加,只需在配置部分中添加configSections即可。并且configSections 必须是配置节的第一个子级,就像下面的代码一样。

<configuration>
  <configSections>
    <section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
  </configSections>
  <connectionStrings>
    <add name="ConnectionString"
    connectionString="data source=20.20.1.1;initial catalog=myDB;user id=sa;password=123456;persist security info=True;MultipleActiveResultSets=True;App=EntityFramework"
    providerName="System.Data.SqlClient"/>
  </connectionStrings>
....
<!-- other configuration -->
....
</configuration>
Run Code Online (Sandbox Code Playgroud)


Ash*_*ada 5

在实体框架中,The type initializer错误很可能是由于Web.config文件格式错误,例如有两个或多个连接字符串部分,或者连接字符串本身存在问题,例如无效的提供程序。


Dia*_*ana 1

这个配置对我有用:

<?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" />
  </configSections>
  <startup>
    <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5.2" />
  </startup>
  <entityFramework>
    <defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlConnectionFactory, EntityFramework" />
    <providers>
      <provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
      <provider invariantName="MySql.Data.MySqlClient" type="MySql.Data.MySqlClient.MySqlProviderServices, MySql.Data.Entity.EF6, Version=6.8.3.0, Culture=neutral, PublicKeyToken=c5687fc88969c44d"></provider>
    </providers>
  </entityFramework>
  <system.data>
    <DbProviderFactories>
      <remove invariant="MySql.Data.MySqlClient" />
      <add name="MySQL Data Provider" invariant="MySql.Data.MySqlClient" description=".Net Framework Data Provider for MySQL" type="MySql.Data.MySqlClient.MySqlClientFactory, MySql.Data, Version=6.8.3.0, Culture=neutral, PublicKeyToken=c5687fc88969c44d" />
    </DbProviderFactories>
  </system.data>
  <connectionStrings>
    <add name="MyLocalDatabase" providerName="MySql.Data.MySqlClient" connectionString="server=localhost;port=3306;database=mycontext;uid=root;password=********" />
  </connectionStrings>
</configuration>
Run Code Online (Sandbox Code Playgroud)

由于MySql在我的开发计算机中错误安装了连接器客户端,我遇到了与您类似的错误。我MySql在 Visual Studio 中安装了连接器 Nuget 包,但这还不够。我还需要安装MySql从网站下载的客户端MySql。之后Type错误就消失了。

这些是我的 Nuget 包: 在此输入图像描述

这是我手动下载并安装的MySql连接器的下载页面

注意:defaultConnectionFactory如果您明确指定提供程序的类型,则永远不会使用该值。在这种情况下,此设置中配置文件中的值并不重要。请参阅MySql 网站的参考文档页面中的第 3 点。

MySql我建议您使用 MySql 命令行客户端控制台检查您的计算机是否已正确安装。尝试使用连接字符串值从 Visual Studio 外部连接到服务器。