gpt4 book ai didi

asp.net-core-2.0 - AspNetCore 2.0.5 Add-Migration 尝试创建表而不是更改现有表

转载 作者:行者123 更新时间:2023-12-05 06:35:45 25 4
gpt4 key购买 nike

AspNetCore.All 2.0.5 决定为迁移创建一个与现有表同名的新表,而不是更改现有表。

Add-Migration 成功生成迁移,但在运行 Update-Database 时会抛出错误,因为同名表已存在.

我可以在开发的这个阶段删除表格或手动修复脚本,但从长远来看这对我没有帮助。我需要了解这里发生了什么以便将来迁移。

这是应用的初始迁移。 DB 只有一张表。

using Microsoft.EntityFrameworkCore.Metadata;
using Microsoft.EntityFrameworkCore.Migrations;
using System;
using System.Collections.Generic;

namespace GameApplication.Migrations
{
public partial class first : Migration
{
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.CreateTable(
name: "UserProfiles",
columns: table => new
{
Id = table.Column<long>(nullable: false)
.Annotation("SqlServer:ValueGenerationStrategy", SqlServerValueGenerationStrategy.IdentityColumn),
Name = table.Column<string>(nullable: true)
},
constraints: table =>
{
table.PrimaryKey("PK_UserProfiles", x => x.Id);
});
}

protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropTable(
name: "UserProfiles");
}
}
}

然后在一个新的添加迁移之后它包括这个:

    migrationBuilder.CreateTable(
name: "UserProfiles",
columns: table => new
{
Id = table.Column<long>(nullable: false)
.Annotation("SqlServer:ValueGenerationStrategy", SqlServerValueGenerationStrategy.IdentityColumn),
City = table.Column<string>(nullable: true),
Country = table.Column<string>(nullable: true),
DisplayName = table.Column<string>(nullable: true),
FirstName = table.Column<string>(nullable: true),
Langauge = table.Column<float>(nullable: false),
LastName = table.Column<string>(nullable: true),
Latitude = table.Column<float>(nullable: false),
Longitude = table.Column<float>(nullable: false),
UserId = table.Column<string>(nullable: true)
},
constraints: table =>
{
table.PrimaryKey("PK_UserProfiles", x => x.Id);
});
  • 它好像完全忽略了之前迁移的存在;没有提到 Name 被删除并替换为 FirstName LastName 的事实,这通常会显示数据丢失警告。什么会导致这种情况发生?

看似相关的未回答问题: Add-Migration not adding column to existing table in Entity Framework Core

最佳答案

我在写问题的时候解决了这个问题,所以:

EF 弄清楚了如何基于 ApplicationContextModelSnapshot.cs 创建新的迁移,而这个文件在我的例子中是不正确的。

这个快照文件对我来说是坏的,因为我的 20180313134743_first.Designer.cs 文件已被修改和评论。这意味着 EF 无法正确创建快照或快照不存在,从而使其在尝试进行新迁移时不知道当前模型状态。

解决方法:

  1. 我使用 remove-migration 命令放弃了新的迁移。
  2. 手动修复快照 - 通过将 20180313134743_first.Designer.cs BuildTargetModel() 的内容复制到 ApplicationContextModelSnapshot.cs BuildModel()
  3. 运行 Update-Database 进行验证,然后运行 ​​Add-Migration,这次它成功地识别出它需要更改现有表。

关于asp.net-core-2.0 - AspNetCore 2.0.5 Add-Migration 尝试创建表而不是更改现有表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49513206/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com