1

我有一个针对在 Mono 上运行的 .net 4.5 的 MVC3 项目,唯一失败的是从实体框架到 PostgreSQL 的连接。

我有一个在 VS 2012 中使用 MVC4、EF6、Postgres 的几乎相同的项目。

我收到以下错误:

System.InvalidOperationException 实体框架提供程序类型“Npgsql.NpgsqlFactory,Npgsql”的“Instance”成员未返回从“System.Data.Entity.Core.Common.DbProviderServices”继承的对象。实体框架提供者必须从此类扩展,并且“实例”成员必须返回提供者的单例实例。

我是否缺少配置中的某些内容或者这不起作用?

<!--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" />
<!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->

和 ...

  <entityFramework>
    <providers>
      <provider invariantName="Npgsql" type="Npgsql.NpgsqlFactory, Npgsql">
      </provider>
    </providers>
  </entityFramework>
  <system.data>
    <DbProviderFactories>
      <remove invariant="Npgsql" />
      <add name="Npgsql Data Provider" invariant="Npgsql" support="FF" description=".Net Framework Data Provider for Postgresql" type="Npgsql.NpgsqlFactory, Npgsql" />
    </DbProviderFactories>
  </system.data>

Mono ASP.net 版本字符串...

Version Information: 3.0.3 (master/39c48d5); ASP.NET Version: 4.0.30319.17020
4

3 回答 3

1

由于更改,您需要 EF6 的 PostgreSQL 连接器。您可以在此处阅读有关情况的更多信息:

http://entityframework.codeplex.com/wikipage?title=Rebuilding%20EF%20providers%20for%20EF6

于 2013-01-28T19:07:47.453 回答
0

我修复了这个错误。

改变

<entityFramework>
  <providers>
    <provider invariantName="Npgsql" type="Npgsql.NpgsqlFactory, Npgsql"></provider>
  </providers>
</entityFramework>

  <entityFramework>
    <providers>
      <provider invariantName="Npgsql" type="Npgsql.NpgsqlServices, Npgsql"></provider>
    </providers>
  </entityFramework>
于 2013-07-05T19:35:03.667 回答
0

将您的 entityFramework 部分配置更改为:

<entityFramework>
  <providers>
    <provider invariantName="Npgsql" type="Npgsql.NpgsqlServices, Npgsql.EntityFramework" />
  </providers>
</entityFramework>

PS:我使用 Npgsql 版本 2.1.0.0

于 2014-02-17T06:33:53.333 回答