我原来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