Kgn*_*web 5 c# mysql asp.net asp.net-mvc entity-framework
我有ASP.Net MVC网站。
技术栈
当我尝试使用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)
在实体框架中,The type initializer错误很可能是由于Web.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" />
</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错误就消失了。
这是我手动下载并安装的MySql连接器的下载页面。
注意:defaultConnectionFactory如果您明确指定提供程序的类型,则永远不会使用该值。在这种情况下,此设置中配置文件中的值并不重要。请参阅MySql 网站的参考文档页面中的第 3 点。
MySql我建议您使用 MySql 命令行客户端控制台检查您的计算机是否已正确安装。尝试使用连接字符串值从 Visual Studio 外部连接到服务器。
| 归档时间: |
|
| 查看次数: |
13730 次 |
| 最近记录: |