为什么我不能先使用ef6代码更新数据库?

时间:2019-03-16 08:38:49

标签: c# mysql entity-framework entity-framework-6

使用ef6连接到godaddy上的MySql数据库时,首先实现代码时遇到问题。它仍在尝试连接到SQL实例

运行update-database

时出现以下错误
  

错误号:53,状态:0,类:20   建立与SQL Server的连接时发生与网络相关或特定于实例的错误。服务器未找到或无法访问。验证实例名称正确,并且已将SQL Server配置为允许远程连接。 (提供者:命名管道提供者,错误:40-无法打开与SQL Server的连接)

这是我的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="LMScontext" connectionString="Server=servername;Database=dbname;Uid=user;Pwd=password;" providerName="MySql.Data.MySqlClient" />
  </connectionStrings>
  <entityFramework>

    <providers>
      <!--<provider invariantName="MySql.Data.MySqlClient" type="MySql.Data.MySqlClient.MySqlProviderServices, MySql.Data.Entity.EF6" />-->
      <!--<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.10.8.0, Culture=neutral, PublicKeyToken=c5687fc88969c44d"/>
    </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.10.8.0, Culture=neutral, PublicKeyToken=c5687fc88969c44d" />
    </DbProviderFactories>
  </system.data>
</configuration>

2 个答案:

答案 0 :(得分:0)

尝试this。我可能会有所帮助

答案 1 :(得分:0)

一种适用于我的情况的解决方案是

<providers>.....</providers>上方的行下方添加

<defaultConnectionFactory type="MySql.Data.MySqlClient.MySqlClientFactory, MySql.Data" />
<providers>
  ...
</providers>

然后从<DbProviderFactories>.....</DbProviderFactories>web.config中删除app.config部分。

然后将以下属性添加到DbContext类实现中

[DbConfigurationType(typeof(MySql.Data.Entity.MySqlEFConfiguration))]

看起来像这样

[DbConfigurationType(typeof(MySql.Data.Entity.MySqlEFConfiguration))] 
public class MySqlDbContext : DbContext 
{
    .....
}