Effort + Autofac: не вернул объект, который наследуется от DbProviderServices
Я использую Effort
, Effort.EF6
как моя база данных в памяти, чтобы проверить мой Web API 2
приложение.
я использую Autofac
для моего решения я.
Это мой код в Startup.cs
builder.Register(c =>
{
var dbConnectionFactory =
Effort.DbConnectionFactory.CreatePersistent(nameof(CvManagementDbContext));
return new CvManagementDbContext(dbConnectionFactory);
})
.As<DbContext>()
.SingleInstance();
И по моему CvManagementDbContext.cs
:
public CvManagementDbContext(DbConnection connection)
: base(connection, true)
{
}
[ОБНОВИТЬ]
Это мое package.config
<?xml version="1.0" encoding="utf-8"?>
<packages>
<package id="ApiMultipartFormDataFormatter" version="1.0.3" targetFramework="net452" />
<package id="Autofac" version="4.8.1" targetFramework="net46" />
<package id="Autofac.WebApi2" version="4.2.0" targetFramework="net46" />
<package id="AutoMapper" version="7.0.1" targetFramework="net46" />
<package id="AutoMapper.EF6" version="1.1.1" targetFramework="net46" />
<package id="DelegateDecompiler" version="0.24.0" targetFramework="net46" />
<package id="DelegateDecompiler.EntityFramework" version="0.24.0" targetFramework="net46" />
<package id="Effort" version="1.3.10" targetFramework="net46" />
<package id="Effort.EF6" version="1.3.10" targetFramework="net46" />
<package id="EntityFramework" version="6.2.0" targetFramework="net46" />
<package id="JWT" version="4.0.0" targetFramework="net46" />
<package id="Microsoft.AspNet.Cors" version="5.2.6" targetFramework="net46" />
<package id="Microsoft.AspNet.WebApi" version="5.2.6" targetFramework="net46" />
<package id="Microsoft.AspNet.WebApi.Client" version="5.2.6" targetFramework="net46" />
<package id="Microsoft.AspNet.WebApi.Core" version="5.2.6" targetFramework="net46" />
<package id="Microsoft.AspNet.WebApi.Cors" version="5.2.6" targetFramework="net46" />
<package id="Microsoft.AspNet.WebApi.Owin" version="5.2.6" targetFramework="net46" />
<package id="Microsoft.AspNet.WebApi.WebHost" version="5.2.6" targetFramework="net46" />
<package id="Microsoft.CodeDom.Providers.DotNetCompilerPlatform" version="2.0.1" targetFramework="net46" />
<package id="Microsoft.Net.Compilers" version="2.9.0" targetFramework="net46" developmentDependency="true" />
<package id="Microsoft.Owin" version="4.0.0" targetFramework="net46" />
<package id="Microsoft.Owin.Host.SystemWeb" version="4.0.0" targetFramework="net46" />
<package id="Mono.Reflection" version="1.1.0.0" targetFramework="net46" />
<package id="Mono.Reflection.Core" version="1.1.1" targetFramework="net46" />
<package id="Newtonsoft.Json" version="11.0.2" targetFramework="net46" />
<package id="NMemory" version="2.0.4" targetFramework="net46" />
<package id="Owin" version="1.0" targetFramework="net46" />
<package id="ServiceStack.Common" version="5.4.0" targetFramework="net46" />
<package id="ServiceStack.Interfaces" version="5.4.0" targetFramework="net46" />
<package id="ServiceStack.Redis" version="5.4.0" targetFramework="net46" />
<package id="ServiceStack.Text" version="5.4.0" targetFramework="net46" />
<package id="System.Buffers" version="4.5.0" targetFramework="net46" />
<package id="System.Memory" version="4.5.1" targetFramework="net46" />
<package id="System.Runtime.CompilerServices.Unsafe" version="4.5.1" targetFramework="net46" />
<package id="System.ValueTuple" version="4.5.0" targetFramework="net46" />
</packages>
Конфигурация Усилия в Web.config
<entityFramework>
<interceptors>
<interceptor type="Cv_Management.Interceptor.GlobalDbCommandInterceptor, Cv_Management" />
</interceptors>
<defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlConnectionFactory, EntityFramework" />
<providers>
<!--<provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />-->
<provider invariantName="Effort.Provider" type="Effort.Provider.EffortProviderServices,Effort" />
</providers>
</entityFramework>
Когда мое приложение запускает исключение, выбрасываемое в консоль, а именно:
Элемент 'Instance' типа поставщика Entity Framework 'Effort.Provider.EffortProviderServices, Effort, Version=1.0.0.0, Culture= нейтральный, PublicKeyToken=6a46696d54971e6d' не возвратил объект, который наследуется от 'System.Data.Entity.Core.Common.DbProviderServices. Поставщики Entity Framework должны наследовать от этого класса, а член 'Instance' должен возвращать одноэлементный экземпляр поставщика. Это может быть связано с тем, что поставщик не поддерживает Entity Framework 6 или более позднюю версию; см. http://go.microsoft.com/fwlink/?LinkId=260882 для получения дополнительной информации. '
Что я не так делаю?
1 ответ
Я думаю, мне удалось воспроизвести вашу проблему. Ты видишь Effort
а также Effort.EF6
являются взаимоисключающими библиотеками, вы только одна из них. Согласно усилию GitHub:
Если вы используете Entity Framework 6...
- Вам понадобится пакет Effort.EF6
- Проверьте официальный сайт NuGet
иначе...
- Вам понадобится пакет усилий
- Проверьте официальный сайт NuGet
Я получил вашу ошибку, когда у меня есть ссылка на DLL из Effort
пакет в моем файле csproj:
<Reference Include="Effort, Version=1.0.0.0, Culture=neutral, PublicKeyToken=6a46696d54971e6d, processorArchitecture=MSIL">
<SpecificVersion>False</SpecificVersion>
<HintPath>..\packages\Effort.1.3.10\lib\net45\Effort.dll</HintPath>
</Reference>
Ошибка исчезла, когда я изменил ссылку на DLL с Effort.EF6
пакет:
<Reference Include="Effort, Version=1.0.0.0, Culture=neutral, PublicKeyToken=6a46696d54971e6d, processorArchitecture=MSIL">
<SpecificVersion>False</SpecificVersion>
<HintPath>..\packages\Effort.EF6.1.3.10\lib\net45\Effort.dll</HintPath>
</Reference>
Проверьте ссылки в вашем файле csproj, убедитесь, что вы используете DLL из Effort.EF6
, И избавиться от Effort
пакет. Надеюсь, поможет.