2017-03-17 61 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