Extending UserRole primary key with additional columns ASP.NET Core EF(使用其他列ASP.NET Core EF扩展UserRole主键)
问题描述
我有一个带有标识模型的ASP.NET Core项目。它使用10.4.17-MariaDB数据库和Pomelo MySQL提供程序。该项目已经在生产中使用,但我想在最新版本中使用新密钥扩展UserRole。我定义了自己的UserRole类,该类扩展了IdentityUserRole,如下所示:
public class UserRole : IdentityUserRole<String>
{
[Key]
public Guid OrganizationId { get; set; }
[Key]
public DateTime Join { get; set; }
...
}
因此,我希望我的用户在多个组织中拥有多个角色,并且具有多个"加入"日期。我手动将Haskey行添加到DB上下文中的实体:
modelBuilder.Entity<UserRole>(entity =>
{
entity.HasKey(m => new { m.UserId, m.RoleId, m.Join, m.OrganizationId });
entity.Property(m => m.UserId).HasMaxLength(127);
entity.Property(m => m.RoleId).HasMaxLength(127);
entity.Property(m => m.OrganizationId).HasMaxLength(127);
entity.Property(m => m.Join);
...
});
当我添加具有这些更改的迁移并尝试执行它时,收到以下错误:
Failed executing DbCommand (31ms) [Parameters=[], CommandType='Text', CommandTimeout='30']
ALTER TABLE `AspNetUserRoles` ADD CONSTRAINT `FK_AspNetUserRoles_AspNetRoles_RoleId` FOREIGN KEY (`RoleId`) REFERENCES `AspNetRoles` (`RoleId`) ON DELETE CASCADE;
如果AspNetRoles
表的主键被调用Id
,迁移为什么要尝试引用RoleId
?
我使用Script-Migration
命令检查了第一次迁移,在创建表期间外键被正确引用到Id
。
推荐答案
原来是我使用的柚子库的Alpha版本中的错误。到那时,这个错误已经在夜间构建中修复了。请参阅Github上的问题#1371。
这篇关于使用其他列ASP.NET Core EF扩展UserRole主键的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:使用其他列ASP.NET Core EF扩展UserRole主键


基础教程推荐
- 在 VS2010 中的 Post Build 事件中将 bin 文件复制到物 2022-01-01
- 经典 Asp 中的 ResolveUrl/Url.Content 等效项 2022-01-01
- 全局 ASAX - 获取服务器名称 2022-01-01
- JSON.NET 中基于属性的类型解析 2022-01-01
- 将事件 TextChanged 分配给表单中的所有文本框 2022-01-01
- 首先创建代码,多对多,关联表中的附加字段 2022-01-01
- 是否可以在 asp classic 和 asp.net 之间共享会话状态 2022-01-01
- 如何动态获取文本框中datagridview列的总和 2022-01-01
- 错误“此流不支持搜索操作"在 C# 中 2022-01-01
- 从 VS 2017 .NET Core 项目的发布目录中排除文件 2022-01-01