我原來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和建立其把我解決以下錯誤:
要確定哪個版本應該用於哪一個版本?我的意思是'MySql.Data.Core'和'MySql.Data.EntityFrameworkCore'的哪一個' – Nitish
你不應該引用'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
好吧,讓我試試這個版本,如果它很爛,那麼我可能會決定更改數據庫 – Nitish