【问题标题】:How to update the existing dbcontext in asp.net core 1.1如何在 asp.net core 1.1 中更新现有的 dbcontext
【发布时间】:2017-01-26 14:52:22
【问题描述】:

我使用下面的命令来创建 dbcontext

Scaffold-DbContext "Data Source=SANPC;Initial Catalog=EMAKITI;Trusted_Connection=True;" Microsoft.EntityFrameworkCore.SqlServer -OutputDir Data

以上命令成功创建了包含所有表的dbcontext。

现在,我已经更改了表格的某些列并使用以下命令进行更新

Scaffold-DbContext -Connection "Data Source=SANPC;Initial Catalog=EMAKITI;Integrated Security=True;Trusted_Connection=True;" -Provider Microsoft.EntityFrameworkCore.SqlServer -OutputDir Entity -context EmakitiContext -Project DataBase -force

上面的命令给我一个错误

指定的deps.json [D:\GitAlpha\eMikitiWebApi\eMikitiWebApiPortal\src\eMikitiWebApiPortal\bin\Debug\netcoreapp1.1\eMikitiWebApiPortal.deps.json] 不存在 进程以非零退出代码结束

我做了很多研究。无法解决这个问题。我使用的是 asp.net core 1.1

这里是 project.json 文件

    {
  "dependencies": {
    "Microsoft.Extensions.Logging": "1.1.0",
    "Microsoft.EntityFrameworkCore.SqlServer": "1.1.0",
    "Microsoft.EntityFrameworkCore.Tools": "1.1.0-preview4-final",
    "Microsoft.EntityFrameworkCore.Design": "1.1.0",
    "Microsoft.EntityFrameworkCore.SqlServer.Design": "1.1.0",
    "DataBase": "1.0.0-*",
    "UnitOfWork": "1.0.0-*",
    "ViewModel": "1.0.0-*",
    "Common": "1.0.0-*",
    "Microsoft.AspNetCore.Session": "1.1.0",
    "Microsoft.Extensions.Caching.Memory": "1.1.0",
    "Microsoft.Extensions.Options.ConfigurationExtensions": "1.1.0",
    "Microsoft.NETCore.App": "1.1.0",
    "System.IdentityModel.Tokens.Jwt": "5.1.2",
    "Microsoft.AspNetCore.Authentication.JwtBearer": "1.1.0",
    "Microsoft.AspNetCore.Diagnostics": "1.1.0",
    "Microsoft.AspNetCore.Mvc": "1.1.0",
    "Microsoft.AspNetCore.Routing": "1.1.0",
    "Microsoft.AspNetCore.Server.IISIntegration": "1.1.0",
    "Microsoft.AspNetCore.Server.Kestrel": "1.1.0",
    "Microsoft.AspNetCore.StaticFiles": "1.1.0",
    "Microsoft.Extensions.Configuration.EnvironmentVariables": "1.1.0",
    "Microsoft.Extensions.Configuration.FileExtensions": "1.1.0",
    "Microsoft.Extensions.Configuration.Json": "1.1.0",
    "Microsoft.Extensions.Logging.Console": "1.1.0",
    "Microsoft.Extensions.Logging.Debug": "1.1.0",
    "Microsoft.AspNetCore.Diagnostics.EntityFrameworkCore": "1.1.0"
  },

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

  "frameworks": {
    "netcoreapp1.1": {
      "imports": [
        "dotnet5.6",
        "portable-net45+win8"
      ]
    }
  },
  "runtimes": {
    "win10-x64": {}
  },

  "buildOptions": {
    "emitEntryPoint": true,
    "preserveCompilationContext": true
  },

  "runtimeOptions": {
    "configProperties": {
      "System.GC.Server": true
    }
  },

  "publishOptions": {
    "include": [
      "wwwroot",
      "**/*.cshtml",
      "appsettings.json",
      "web.config"
    ]
  },

  "scripts": {
    "postpublish": [ "dotnet publish-iis --publish-folder %publish:OutputPath% --framework %publish:FullTargetFramework%" ]
  }
}

【问题讨论】:

  • 尝试删除现有文件,然后重新创建。确保在删除之前创建备份。
  • 不,它没有帮助......同样的问题......我已经将 .net 核心从 1.0 更新到 1.1,现在我正面临这个问题

标签: c# entity-framework asp.net-core


【解决方案1】:

您正在使用代码优先方法,并且在这种方法中,更改从代码流向数据库。实体框架让我们可以选择从现有数据库开始进行逆向工程。当我们进行一次逆向工程来生成我们的模型时,之后我们需要遵循代码优先方法代码到数据库的迁移流程。

使用这个命令我们生成迁移

dotnet ef migrations add InitialCreate -c SchoolContext

然后我们将它应用到数据库中。

dotnet ef database update -c SchoolContext

你可以了解更多关于这个here

【讨论】:

  • 我没有使用代码优先的方法。问题出在我将 asp.net core 1.0 更新到 asp.net core 1.1 时。当我使用 1.0 时,相同的命令正在运行,现在该命令不起作用
猜你喜欢
  • 1970-01-01
  • 2017-05-15
  • 1970-01-01
  • 2016-05-26
  • 1970-01-01
  • 2017-07-12
  • 1970-01-01
  • 2017-06-18
  • 1970-01-01
相关资源
最近更新 更多