使用其他列ASP.NET Core EF扩展UserRole主键

Extending UserRole primary key with additional columns ASP.NET Core EF(使用其他列ASP.NET Core EF扩展UserRole主键)
本文介绍了使用其他列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主键的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

DispatcherQueue null when trying to update Ui property in ViewModel(尝试更新ViewModel中的Ui属性时DispatcherQueue为空)
Drawing over all windows on multiple monitors(在多个监视器上绘制所有窗口)
Programmatically show the desktop(以编程方式显示桌面)
c# Generic Setlt;Tgt; implementation to access objects by type(按类型访问对象的C#泛型集实现)
InvalidOperationException When using Context Injection in ASP.Net Core(在ASP.NET核心中使用上下文注入时发生InvalidOperationException)
LINQ many-to-many relationship, how to write a correct WHERE clause?(LINQ多对多关系,如何写一个正确的WHERE子句?)