• Code First 中的 TPH TPT TPC


          public class Blog
          {
                public int Id { get; set; }
                public DateTime Creationdate { get; set; }
                public string ShortDescription { get; set; }
                public string Title { get; set; }
                public string AboutTheAuthor { get; set; }
          }
    
          public class PictureBlog : Blog
          {
                public string PicDescription { get; set; }
          }
    
          public class VideoBlog : Blog
          {
                public string VideoDescription { get; set; }
          }

    配置 TPH 形成的数据表(一张表存放基类和子类的所有列,特定列区分):

    默认配置

    其中BlogType 可以修改的,如改成From,则这样:

    this.Map<Blog>(l => { l.Requires("From").HasValue("Blog"); });
    
    this.Map<Picture>(l => { l.Requires("From").HasValue("Pic"); });

    this.Map<Video>(l => { l.Requires("From").HasValue("Video"); });
     

    配置 TPT 形成的数据表(父类和子类在不同的表里,有主外键关系):

    this.Map(m => {

           m.ToTable("Blogs");

         }).Map<PictureBlog>(m =>{

                    m.ToTable("PictureBlogs");
    })
    .Map<VideoBlog>(m => {
                    m.ToTable("VideoBlogs");
    });

    配置 TPC 形成的数据表(子类包含父类的所有属性,各自独立):

    this.Map(m => {

           m.ToTable("Blogs");

         }).Map<PictureBlog>(m =>{

                    m.ToTable("PictureBlogs");
        m.MapInheritedProperties();
                }).Map<VideoBlog>(m => {
                    m.ToTable("VideoBlogs");
        m.MapInheritedProperties();
                });

  • 相关阅读:
    TapTap推广统计逻辑
    广告推广测试
    背压(Backpressure)机制
    工作相关资料
    ElasticSearch问题记录
    bfrd collector性能排查
    Ubuntu13.10下安装HADOOP
    Hadoop各商业发行版之比较
    Behave用户自定义数据类型
    Behave step matcher
  • 原文地址:https://www.cnblogs.com/yipeng-yu/p/4418003.html
Copyright © 2020-2023  润新知