EFCore Study(番外1)——单向导航属性

一、单向导航属性场景

1、比如公司OA系统有很多相关的审批流程,比如离职(Leave)、请假(relex)、加班,每个流程都有多级审批人,每个审批人都是User

一个人(User)——多个审批流程的多个审批人(Apply)

User:Id,Name

Apply:Id ,type,applyUser,Approver

此时做映射的时候只适合在多(Apply) 配置一(User),不适合在User类加List<Leave>、List<relex>,,,,

二、配置方法

EFCore Study(番外1)——单向导航属性

 

 

//User配置
public void Configure(EntityTypeBuilder<User> builder) { builder.ToTable("user"); builder.Property(b => b.Id).IsUnicode().ValueGeneratedOnAdd(); builder.Property(b => b.Name).IsRequired().HasMaxLength(50); }
public class CommentMap:IEntityTypeConfiguration<Apply>
    {
        public void Configure(EntityTypeBuilder<Apply> builder)
        {
            builder.ToTable("apply");
            builder.Property(b => b.Id).IsUnicode().ValueGeneratedOnAdd();
            builder.Property(b => b.remark).IsRequired().HasMaxLength(100);
            //指定一个外键申请人,withMany不设置参数
            builder.HasOne<User>(a=>a.applyUser).WithMany().IsRequired();
        }
    }

 3、单向导航和双向导航的选择

EFCore Study(番外1)——单向导航属性

 

上一篇:Error attempting to get column 'xxx' from result set. Cause: java.sql.SQLException: 无法转换为


下一篇:2021-10-10