找不到具有不变名称“System.Data.SqlClient”的 ADO.NET 提供程序的实体框架提供程序。

Posted

技术标签:

【中文标题】找不到具有不变名称“System.Data.SqlClient”的 ADO.NET 提供程序的实体框架提供程序。【英文标题】:No Entity Framework provider found for the ADO.NET provider with invariant name 'System.Data.SqlClient'. 【发布时间】:2014-02-06 04:22:24 【问题描述】:

我们正在使用带有 Code First 的 EntityFramework 6。我们有一个控制台应用程序,它没有引用 EntityFramework,但从其 App.config 中读取连接字符串。它调用 DatabaseInitializationUtilities 程序集,将连接字符串作为参数传递。

DatabaseInitializationUtilities 引用了 EF6(EntityFramework 和 EntityFramework.SqlServer)。它的 App.config 是这样的:

<?xml version="1.0" encoding="utf-8"?>
  <configuration>
     <configSections>
        <!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->
      <section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
     </configSections>
     <system.serviceModel>
         <bindings>
            <basicHttpBinding>
                <binding name="BasicHttpBinding_IAuthentication" />
            </basicHttpBinding>
         </bindings>
         <client>
            <endpoint address="http://localhost/SecurityServices/Authentication.svc" binding="basicHttpBinding" bindingConfiguration="BasicHttpBinding_IAuthentication" contract="SecurityService.IAuthentication" name="BasicHttpBinding_IAuthentication" />
         </client>
      </system.serviceModel>
      <entityFramework>
         <defaultConnectionFactory type="System.Data.Entity.Infrastructure.LocalDbConnectionFactory, EntityFramework">
            <parameters>
               <parameter value="v11.0" />
            </parameters>
         </defaultConnectionFactory>
         <providers>
            <provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
         </providers>
      </entityFramework>
   </configuration>

当执行到达 DatabaseInitializationUtilities 尝试运行脚本的行时

context.Database.ExecuteSqlCommand(script.ScriptText)

抛出错误:

确保提供程序已在应用程序配置文件的“entityFramework”部分注册。请参阅http://go.microsoft.com/fwlink/?LinkId=260882 了解更多信息。

我相信补救措施正是我的配置文件中的内容,所以我不明白这个问题。

注意:Resharper 正在蓝化节点并报告 "元素 'EntityFramework' 的子元素 'providers' 无效。但是,该部分是在我安装 EF6 时由 NuGet 注入的。

有什么想法吗?

【问题讨论】:

看看下面的问题:***.com/questions/14033193/… 谢谢。对 [***.com/questions/14033193/… 的评论很有帮助。 [1]:***.com/questions/14033193/… 将 EntityFramework.SqlServer.dll 添加到客户端应用程序并将连接字符串添加到其 app.config 文件中就可以了。现在错误消失了***.com/questions/18455747/… 在我们的例子中,EF 程序集是 GACed。在这种情况下,您应该在配置文件中使用完整的程序集名称: No Entity Framework provider found for the ADO.NET provider with invariant name 'System.Data.SqlClient'的可能重复 【参考方案1】:

您需要创建一个引用,因此它将被复制到调试文件夹中。所以稍后它可以在运行时访问。

不要复制任何文件,只需创建此引用:

private volatile Type _dependency;

public MyClass()

    _dependency = typeof(System.Data.Entity.SqlServer.SqlProviderServices);

【讨论】:

史诗般的胜利!它失败的原因是只有直接使用的程序集才会被复制。此程序集没有直接引用,因此不会被复制。 我认为 EF 团队对此有一些重要的解释。 下载 dll 并将其手动添加到您的主应用程序中。确保属性下的“复制本地 = true”。我不会推荐该问题的解决方案,因为当您更新实体模型时,解决方法代码将被删除。 这真的很有趣。不知道它是如何工作的,但它确实有效:-)【参考方案2】:

您的应用程序路径中是否有程序集 EntityFramework.SqlServer.dll? 我遇到了同样的问题,将 dll 复制到应用程序路径后,一切正常。

【讨论】:

我遇到了同样的问题,并通过添加缺少的 EntityFramework.SqlServer.dll 来修复【参考方案3】:

终于在这篇博客中找到了答案:

http://robsneuron.blogspot.com/2013/11/entity-framework-upgrade-to-6.html

【讨论】:

Yeo,这也是我的问题...我删除了整个数据库并从头开始检查解决方案,在第一次构建之后,我得到了这个确切的“错误消息”:-) 插入不稳定的参考和它的工作。 为什么不在这里简单提一下它的主要思想呢? @Deilan 这个想法和 dh_cgn 中的一样 回答***.com/a/21531672/52277【参考方案4】:

我也有这个问题。当我运行我的 .net mvc 应用程序时,一切都在本地工作,但是当我发布它时,我得到了这个错误。问题是我必须在我的 Web 项目中也引用 EntityFrameworl.SqlServer,尽管我有单独的 Data 项目。奇怪的是,这个错误只在应用发布时抛出。这可能是来自 Microsoft 的一些严重错误。我用的是 EF 6.1.1。

【讨论】:

我遇到了同样的问题。我对 ef 程序集的引用位于从我的 mvc 项目引用的单独数据项目中。我将 ef 从 nuget 安装到我的 mvc 项目中,重新发布并且它有效。感谢修复【参考方案5】:

这是因为EntityFramework.SqlServer.dll没有复制到您的项目中。添加该 dll,它有望工作。您可以从添加数据模型的项目中找到它。

【讨论】:

【参考方案6】:

对我来说,我在 web.config 文件中的提供者引用是不正确的。我相信 nuget 包可能没有正确包含提供程序。

我用这个替换了我的提供者并且它起作用了:

  <entityFramework>
      <defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlConnectionFactory, EntityFramework" />
      <providers>
          <provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
      </providers>
  </entityFramework>

【讨论】:

【参考方案7】:

我也有类似的问题

通过执行以下操作解决了我的问题:

【讨论】:

【参考方案8】:

解决此类问题的最佳方法是将引用 EntityFramework.SqlServer.dll 包含到您的项目中,然后按 F4(操作属性)将属性更改为 Copy to Local =True 所以每次当发布应用程序时,它将被复制到发布的文件夹中。

【讨论】:

【参考方案9】:

我倾向于将 EntityFramework 添加到 Web 项目以及实际引用它的程序集。

【讨论】:

【参考方案10】:

将“EntityFramework.SqlServer.dll”添加到您的项目 bin 文件夹中将解决您的问题。

【讨论】:

以上是关于找不到具有不变名称“System.Data.SqlClient”的 ADO.NET 提供程序的实体框架提供程序。的主要内容,如果未能解决你的问题,请参考以下文章

找不到具有不变名称“System.Data.SqlClient”的 ADO.NET 提供程序的实体框架提供程序

错误:找不到具有不变名称“System.Data.SqlClient”的 ADO.NET 提供程序的实体框架提供程序

在 ASP.NET Core Web API 的已注册 .NET 数据提供程序列表中找不到指定的不变名称“System.Data.sqlClient”

Angular 7:“找不到具有未指定名称属性的控件”

找不到具有名称/键 X 的资源

“找不到具有名称的端点元素...”