没有找到实体框架提供程序.System.Data.SqlClient'

本文关键字:Data System SqlClient 程序 实体 框架 | 更新日期: 2023-09-27 18:08:15

这里的帖子似乎都没有解决我的错误的这个特定版本,但我可能只是错过了一些东西…

:

MVC网站使用WCF服务。数据保存在WCF服务中。都在运行

    <section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />

都有连接字符串:

    <add name="SiteTrackerEntities" connectionString="metadata=res://*/VisitorInformation.csdl|res://*/VisitorInformation.ssdl|res://*/VisitorInformation.msl;provider=System.Data.SqlClient;provider connection string=&quot;data source=BADLANDS';initial catalog=SiteTracker;integrated security=True;MultipleActiveResultSets=True;App=EntityFramework&quot;" providerName="System.Data.EntityClient" />

站点运行,直到我实际尝试使用(第二行错误)保存到WCF服务中的数据库…

SiteTrackerEntities db = new SiteTrackerEntities();
db.Entry(visitorData).State = System.Data.Entity.EntityState.Added; 
然后我得到这个可爱的错误:
VisitorInformation.ssdl(2,2) : error 0152: No Entity Framework provider found for the ADO.NET provider with invariant name 'System.Data.SqlClient'. Make sure the provider is registered in the 'entityFramework' section of the application config file. See http://go.microsoft.com/fwlink/?LinkId=260882 for more information.
  • 确保两者都使用相同版本的EF(6.0)。检查。
  • 尝试在连接字符串中输入提供商名称,但已经使用providerName="System.Data.EntityClient"
  • 尝试使用PM控制台删除并重新安装EF。检查。
  • 手动删除Ef引用并读取它们。检查。
  • WCF服务引用了Entity.Framework.SqlServer(版本6.0.0.0)。检查。
  • MVC应用程序有连接到数据库的字符串,只在WCF服务中使用(奇怪的是它需要它,但没关系)。检查。

我错过了什么?

没有找到实体框架提供程序.System.Data.SqlClient'

确保您的Web中有类似于以下内容的内容。

<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>