• EF Core导航属性


    原文地址:https://www.jianshu.com/p/c6896a651cfb

    EF Core导航属性分为三种:
    集合导航属性:主表中对子表相关数据的引用
    引用导航属性:子表中对主表数据的引用
    反转导航属性:一个导航属性对应的另一端的导航属性
    微软的示例:
    Blog是主表,Post是子表

    public class Blog
    {
        public int BlogId { get; set; }
        public string Url { get; set; }
    
    <span class="token keyword">public</span> List<span class="token operator">&lt;</span>Post<span class="token operator">&gt;</span> Posts <span class="token punctuation">{</span> <span class="token keyword">get</span><span class="token punctuation">;</span> <span class="token keyword">set</span><span class="token punctuation">;</span> <span class="token punctuation">}</span>
    

    }

    public class Post
    {
    public int PostId { get; set; }
    public string Title { get; set; }
    public string Content { get; set; }

    <span class="token keyword">public</span> <span class="token keyword">int</span> BlogId <span class="token punctuation">{</span> <span class="token keyword">get</span><span class="token punctuation">;</span> <span class="token keyword">set</span><span class="token punctuation">;</span> <span class="token punctuation">}</span>
    <span class="token keyword">public</span> <span class="token class-name">Blog</span> Blog <span class="token punctuation">{</span> <span class="token keyword">get</span><span class="token punctuation">;</span> <span class="token keyword">set</span><span class="token punctuation">;</span> <span class="token punctuation">}</span>
    

    }

    在以上实体类的定义中:
    Blog.Posts是集合导航属性,包含子表中的关联数据。
    Post.Blog是引用导航属性,包含主表中的关联数据。
    Post.Blog是Blog.Posts的反转导航属性,反过来也一样。
    通过子表查询主表数据:
    var post=db.Posts.Include("Blog").First();
    可以访问到Blog表的其它字段:
    Console.Write(post.Blog.Url)
    通过主表访问子表数据:
    var blog=db.Blogs.Include(b=>b.Posts).First();
    可以访问子表相关的所有数据:

    foreach(var post in blog.Posts)
    {
        Console.Write(post.Title);
    }
    

    通过引用导航属性访问主表数据,不需要额外定义。
    通过集合导航属性访问子表数据,需要使用Fluent API配置。重写数据上下文的OnModelCreating方法,加入以下代码:

    builder.Entity<Post>()
            .HasOne(post => post.Blog)
            .WithMany(bolg => blog.Posts);
    

    如果不使用Fluent API进行配置,执行var blog=db.Blogs.Include(b=>b.Posts).First();时会报数据库语法错误。

  • 相关阅读:
    django 项目需要注意的一些点
    VUE之路
    Oracle 表格碎片的查看方法
    RHEL 6.x or 7.x 使用分区绑定ASM 磁盘的方法
    RMAN 修复主库 nologging 操作导致物理备库的坏块
    Oracle 数据库19c 回退降级到 11.2.0.4 方案
    如何评估oracle 数据库rman全备和增量备份大小
    在将Oracle GI和DB升级到19c或降级到以前的版本之前需要应用的补丁 (Doc ID 2668071.1)
    Oracle 数据库坏块处理
    opatch auto 安装11.2.0.4.20190115 PSU遇到 OUI-67133: Execution of PRE script failed,with returen value 1 报错
  • 原文地址:https://www.cnblogs.com/dawenxi0/p/11769819.html
Copyright © 2020-2023  润新知