【问题标题】:How to add a foreign key to ApplicationUser between separate project in EF Core?如何在 EF Core 中的单独项目之间向 ApplicationUser 添加外键?
【发布时间】:2021-02-25 03:16:34
【问题描述】:

.NET 5.0.0 中有一个带有 Asp.Net Core Hosting 的 Blazor WebAssembly 应用程序,它独立于 3 个不同的项目:WebApp.ClientWebApp.ServerWebApp.Shared

我正在使用AspNetCore.IdentityIdentityServer4 来管理我的应用程序用户。

但是ApplicationUser : IdentityUser 类在WebApp.Server 项目中,而我的模型类FooWebApp.Shared 项目中。 (WebApp.Server项目有WebApp.Shared项目的引用,所以Foo不能using WebApp.Server.Models。)

我可以在单独的项目之间为ApplicationUser 类添加外键吗?或者我可以将ApplicationUser 移动到WebApp.Shared 项目吗?

代码

// WebApp.Server.Models.ApplicationUser

public class ApplicationUser : IdentityUser
{
    public virtual List<Foo> Foos { get; set; }
}
// WebApp.Shard.Models.Foo
public class Foo
{
    public int ApplicationUserId { get; set; }
    public virtual ApplicationUser ApplicationUser { get; set; } // CS0246 
}

【问题讨论】:

  • 你不能有一个双向关系,你能解释一下你试图这样做的背景吗?也许有更好的选择
  • @nalnpir Foo 是一种活动。我想从两个表中记录哪个用户正在参加此活动以及该用户参加了哪个活动。
  • 您实际上可以将模型本身移动到共享部分......并且您可以侥幸逃脱。我不知道为什么服务器应该使用的东西会在共享部分。老实说,我的想法是您可能应该重新考虑您的架构
  • @nalnpir 我同意你的看法。也许我需要重新构建我的解决方案,因为它现在真的很混乱。
  • 如果可能的话,最好将您的共享课程移动到共享项目中。

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


【解决方案1】:

没有很多依赖的方法是:

// WebApp.Shard.Models.Foo

using System.ComponentModel.DataAnnotations.Schema;

public class Foo<TUser>
{
    public int ApplicationUserId { get; set; }

    [ForeignKey(nameof(ApplicationUserId))]
    public virtual TUser ApplicationUser { get; set; }
}

【讨论】:

  • 是否可以添加多个外键,如AApplicationUserIdBApplicationUserId
  • @DCTewi 您需要更详细地描述一下您的用户 foo 关系吗?
  • 非常抱歉缺少详细信息,感谢您的帮助。我发现我的架构太糟糕而且令人困惑。所以我会用一个简单的模型关系重构我的项目。
猜你喜欢
  • 1970-01-01
  • 2015-09-28
  • 1970-01-01
  • 1970-01-01
  • 2023-02-01
  • 1970-01-01
  • 2017-05-08
  • 2019-11-26
  • 2014-11-01
相关资源
最近更新 更多