2017-03-17 25 views
-1

我原来projects.json文件就像下面:怎样型升级MySQL的EF核心1.1

"dependencies": { 
    "Microsoft.NETCore.App": { 
     "version": "1.0.1", 
     "type": "platform" 
    }, 
    "Microsoft.ApplicationInsights.AspNetCore": "1.0.0", 
    "Microsoft.AspNetCore.Mvc": "1.0.1", 
    "Microsoft.AspNetCore.Routing": "1.0.1", 
    "Microsoft.AspNetCore.Server.IISIntegration": "1.0.0", 
    "Microsoft.AspNetCore.Server.Kestrel": "1.0.1", 
    "Microsoft.Extensions.Configuration.EnvironmentVariables": "1.0.0", 
    "Microsoft.Extensions.Configuration.FileExtensions": "1.0.0", 
    "Microsoft.Extensions.Configuration.Json": "1.0.0", 
    "Microsoft.Extensions.Logging": "1.0.0", 
    "Microsoft.Extensions.Logging.Console": "1.0.0", 
    "Microsoft.Extensions.Logging.Debug": "1.0.0", 
    "Microsoft.Extensions.Options.ConfigurationExtensions": "1.0.0", 
    "Microsoft.EntityFrameworkCore": "1.0.0", 
    "MySql.Data.Core": "7.0.4-IR-191", 
    "MySql.Data.EntityFrameworkCore": "7.0.6-IR31", 
    "Swashbuckle": "6.0.0-beta902", 
    "Microsoft.EntityFrameworkCore.Tools": { 
     "version": "1.0.0-preview2-final", 
     "type": "build" 
    } 
    }, 

    "tools": { 
    "Microsoft.AspNetCore.Server.IISIntegration.Tools": "1.0.0-preview2-final", 
    "Microsoft.EntityFrameworkCore.Tools": "1.0.0-preview2-final" 

    }, 

    "frameworks": { 
    "netcoreapp1.0": { 
     "imports": [ 
     "dotnet5.6", 
     "portable-net45+win8" 
     ] 
    } 
    }, 

这些设置与我的MySQL数据库。 我想升级EF核心到1.1,以便我可以在我的库中使用Update()方法,如下所示(这是很好的一行代码,我不需要将每个属性传入的对象分配给原始对象):

public void UpdateBook(long id, Book book) 
    { 
    var originalBook= _db.Books.FirstOrDefault(o => o.Id == id); 
    _db.Entry(originalBook).CurrentValues.SetValues(book); 
    _db.SaveChanges(); 
    } 

然而,当我升级EF核心,以1.1 "Microsoft.EntityFrameworkCore": "1.0.0"我的代码开始在这些线路中startup.cs抛出错误:

services.AddApplicationInsightsTelemetry(Configuration); 
services.AddDbContext<WebAPIDataContext>(options => 
    { 
      options.UseMySQL(Configuration.GetConnectionString("SampleConnection")); 
      }); 

我的猜测是升级EF核心爆出与MySQL一些依赖。这是对的吗?我该如何解决它?

UPDATE

我删除"Microsoft.EntityFrameworkCore": "1.0.0""MySql.Data.Core": "7.0.4-IR-191""MySql.Data.EntityFrameworkCore": "6.10.1-beta"取代。在我aspsettings.josn我:

"ConnectionStrings": { 
    "SampleConnection": "server=localhost;userid=root;pwd=root;port=3306;database=aspnet;sslmode=none;" 
    }, 

恢复软件包后,我重新启动Visual Studio和建立其把我解决以下错误:

enter image description here

回答

1
"MySql.Data.Core": "7.0.4-IR-191", 
"MySql.Data.EntityFrameworkCore": "7.0.6-IR31", 

两者都是过时和Oracle性交完成版本控制。请参阅NuGet page

IR31是支持EF Core 1.0的最后一个版本。 IR-191甚至更老,并且其中一个6.*是第一个支持EF Core 1.1的。

现在又有7.0.7-m6这似乎也支持EF Core 1.1。甲骨文似乎正在与版本跳绳。

后两个版本中的任一个应该工作6.10.1-beta7.0.7-m6

+0

要确定哪个版本应该用于哪一个版本?我的意思是'MySql.Data.Core'和'MySql.Data.EntityFrameworkCore'的哪一个' – Nitish

+0

你不应该引用'MySql.Data.Core',只有'MySql.Data.EntityFrameworkCore'。就像我上面所说的,Oracle几乎搞砸了版本。现在'7.0.7-m6'未在金块上列出(昨天上市)。 https://www.nuget.org/packages/MySql.Data.EntityFrameworkCore/7.0.7-m6将其显示为不公开。我认为最好的选择是使用'6.10.1-beta'。或者甚至更好,不要使用MySQL完全可以使用Postgresql或MSSQL数据库之一,它具有更好的EF驱动程序/提供程序支持 – Tseng

+0

好吧,让我试试这个版本,如果它很烂,那么我可能会决定更改数据库 – Nitish