列与引用列的长度或比例不同
column is not the same length or scale as referencing column
我在迁移生成器上收到错误消息,其中一列的长度或比例与引用列不同。
以上是 table 我正在尝试创建迁移生成器,它抱怨 UserId。
这是我的两个 tables 的迁移生成器代码。
migrationBuilder.CreateTable(
name: "AspNetUsers",
columns: table => new
{
Id = table.Column<string>(nullable: false),
UserName = table.Column<string>(maxLength: 256, nullable: true),
FirstName = table.Column<string>(maxLength: 256, nullable: true),
LastName = table.Column<string>(maxLength: 256, nullable: true),
NormalizedUserName = table.Column<string>(maxLength: 256, nullable: true),
Email = table.Column<string>(maxLength: 256, nullable: true),
NormalizedEmail = table.Column<string>(maxLength: 256, nullable: true),
EmailConfirmed = table.Column<bool>(nullable: false),
PasswordHash = table.Column<string>(nullable: true),
SecurityStamp = table.Column<string>(nullable: true),
ConcurrencyStamp = table.Column<string>(nullable: true),
PhoneNumber = table.Column<string>(nullable: true),
PhoneNumberConfirmed = table.Column<bool>(nullable: false),
TwoFactorEnabled = table.Column<bool>(nullable: false),
LockoutEnd = table.Column<DateTimeOffset>(nullable: true),
LockoutEnabled = table.Column<bool>(nullable: false),
AccessFailedCount = table.Column<int>(nullable: false),
},
constraints: table =>
{
table.PrimaryKey("PK_AspNetUsers", x => x.Id);
});
这是 aspnet 用户 table 那么这是组织 table
migrationBuilder.CreateTable(
name: "Organization",
columns: table => new
{
OrganizationId = table.Column<int>(nullable: false)
.Annotation("SqlServer:Identity", "1,1"),
DistrictId = table.Column<int>(nullable: true),
Name = table.Column<string>(nullable: true),
Address1 = table.Column<string>(nullable: true),
Address2 = table.Column<string>(nullable: true),
City = table.Column<string>(nullable: true),
State = table.Column<string>(nullable: true),
Zip = table.Column<string>(nullable: true),
Country = table.Column<string>(nullable: true),
County = table.Column<string>(nullable: true),
Latitude = table.Column<string>(nullable: true),
Longitude = table.Column<string>(nullable: true),
TimeZone = table.Column<string>(nullable: true),
UserId = table.Column<string>(nullable: true),
OrganizationLogo = table.Column<string>(nullable: true),
SubscriptionId = table.Column<int>(nullable: true),
DateAdded = table.Column<DateTime>(nullable: true),
DateDeleted = table.Column<DateTime>(nullable: true),
DateUpdated = table.Column<DateTime>(nullable: true),
UpdatedBy = table.Column<string>(nullable: true),
AddedBy = table.Column<string>(nullable: true),
DeletedBy = table.Column<string>(nullable: true),
},
constraints: table =>
{
table.PrimaryKey("PK_Organization", x => new {x.OrganizationId });
table.ForeignKey(
name: "FK_Organization_District_DistrictId",
column: x => x.DistrictId,
principalTable: "District",
principalColumn: "DistrictId",
onDelete: ReferentialAction.Cascade
);
table.ForeignKey(
name: "FK_Organization_AspNetUsers_UserId",
column: x => x.UserId,
principalTable: "AspNetUsers",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade
);
table.ForeignKey(
name: "FK_Organization_Subscription_SubscriptionId",
column: x => x.SubscriptionId,
principalTable: "Subscription",
principalColumn: "SubscriptionId",
onDelete: ReferentialAction.Cascade
);
});
我尝试在组织 table 上将 userid nullable 设置为 false,但没有帮助。我不确定在这里要做什么才能建立我想要的关系。
可能是因为创建的列具有不同的 nvarchar 长度。尝试将迁移中的 PK/FK 列的 maxLength 指定为 450。
我在迁移生成器上收到错误消息,其中一列的长度或比例与引用列不同。
以上是 table 我正在尝试创建迁移生成器,它抱怨 UserId。
这是我的两个 tables 的迁移生成器代码。
migrationBuilder.CreateTable(
name: "AspNetUsers",
columns: table => new
{
Id = table.Column<string>(nullable: false),
UserName = table.Column<string>(maxLength: 256, nullable: true),
FirstName = table.Column<string>(maxLength: 256, nullable: true),
LastName = table.Column<string>(maxLength: 256, nullable: true),
NormalizedUserName = table.Column<string>(maxLength: 256, nullable: true),
Email = table.Column<string>(maxLength: 256, nullable: true),
NormalizedEmail = table.Column<string>(maxLength: 256, nullable: true),
EmailConfirmed = table.Column<bool>(nullable: false),
PasswordHash = table.Column<string>(nullable: true),
SecurityStamp = table.Column<string>(nullable: true),
ConcurrencyStamp = table.Column<string>(nullable: true),
PhoneNumber = table.Column<string>(nullable: true),
PhoneNumberConfirmed = table.Column<bool>(nullable: false),
TwoFactorEnabled = table.Column<bool>(nullable: false),
LockoutEnd = table.Column<DateTimeOffset>(nullable: true),
LockoutEnabled = table.Column<bool>(nullable: false),
AccessFailedCount = table.Column<int>(nullable: false),
},
constraints: table =>
{
table.PrimaryKey("PK_AspNetUsers", x => x.Id);
});
这是 aspnet 用户 table 那么这是组织 table
migrationBuilder.CreateTable(
name: "Organization",
columns: table => new
{
OrganizationId = table.Column<int>(nullable: false)
.Annotation("SqlServer:Identity", "1,1"),
DistrictId = table.Column<int>(nullable: true),
Name = table.Column<string>(nullable: true),
Address1 = table.Column<string>(nullable: true),
Address2 = table.Column<string>(nullable: true),
City = table.Column<string>(nullable: true),
State = table.Column<string>(nullable: true),
Zip = table.Column<string>(nullable: true),
Country = table.Column<string>(nullable: true),
County = table.Column<string>(nullable: true),
Latitude = table.Column<string>(nullable: true),
Longitude = table.Column<string>(nullable: true),
TimeZone = table.Column<string>(nullable: true),
UserId = table.Column<string>(nullable: true),
OrganizationLogo = table.Column<string>(nullable: true),
SubscriptionId = table.Column<int>(nullable: true),
DateAdded = table.Column<DateTime>(nullable: true),
DateDeleted = table.Column<DateTime>(nullable: true),
DateUpdated = table.Column<DateTime>(nullable: true),
UpdatedBy = table.Column<string>(nullable: true),
AddedBy = table.Column<string>(nullable: true),
DeletedBy = table.Column<string>(nullable: true),
},
constraints: table =>
{
table.PrimaryKey("PK_Organization", x => new {x.OrganizationId });
table.ForeignKey(
name: "FK_Organization_District_DistrictId",
column: x => x.DistrictId,
principalTable: "District",
principalColumn: "DistrictId",
onDelete: ReferentialAction.Cascade
);
table.ForeignKey(
name: "FK_Organization_AspNetUsers_UserId",
column: x => x.UserId,
principalTable: "AspNetUsers",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade
);
table.ForeignKey(
name: "FK_Organization_Subscription_SubscriptionId",
column: x => x.SubscriptionId,
principalTable: "Subscription",
principalColumn: "SubscriptionId",
onDelete: ReferentialAction.Cascade
);
});
我尝试在组织 table 上将 userid nullable 设置为 false,但没有帮助。我不确定在这里要做什么才能建立我想要的关系。
可能是因为创建的列具有不同的 nvarchar 长度。尝试将迁移中的 PK/FK 列的 maxLength 指定为 450。