EFCore Study(四)——Select的应用及不走联表查外键字段的操作

一、EFCore里Select的应用:

1)避免查询select *,可指定查询合适的字段

var comment = context.artitles.Select(c =>new { Id = c.Id, Content = c.Content } ).Single(c => c.Id == 1);

2)可灵活选择实体类接收EFCore的查询结果

比如我们为了避免暴露数据库表entity里的字段,采用entityDTO实体去重新命名字段名称,传递给前台。

指定一个传值给前台的DTO实体类

 public class ArticleDTO
    {
        public string ArticleTtitle { get; set; }
        public string ArticleContent { get; set; }

    }
//用entityDTO接收entity的查询结果
List<ArticleDTO> list = context.artitles.Select(ac=>new ArticleDTO(){ArticleTtitle = ac.Ttile, ArticleContent = ac.Content }).ToList<ArticleDTO>();

二、不走联表查外键字段的操作

问题:不走include联表查询,在Comment查找出对应外键theArtitleId的值

我们在Demo2里定义了Comment是

 public  class Comment
    {
        public int Id { get; set; }
        public string Message { get; set; }
        public Artitle theArtitle { get; set; }
    }

解决:

1、在类里定义外键theArtitleId

 public  class Comment
    {
        public int Id { get; set; }
        public string Message { get; set; }
        public Artitle theArtitle { get; set; }
        //定义外键的字段
        public int theArtitleId { get; set; }
    }

2、在映射表里去声明

public class CommentMap:IEntityTypeConfiguration<Comment>
    {
        public void Configure(EntityTypeBuilder<Comment> builder)
        {
            builder.ToTable("comment");
            builder.Property(b => b.Id).IsUnicode().ValueGeneratedOnAdd();
            builder.Property(b => b.Message).IsRequired().HasMaxLength(50);
            //指定一个外键theArtitle,artitle包含多个Comments,HasForeignKey指定对应的外键
 builder.HasOne<Artitle>(a=>a.theArtitle).WithMany(c=>c.Comments).HasForeignKey("theArtitleId").IsRequired(); } }

查询:

var comment = context.comments.Single(c => c.Id == 1);
                Console.WriteLine("评论:" + comment.Message);
                Console.WriteLine("评论对应文章ID:" + comment.theArtitleId);

EFCore Study(四)——Select的应用及不走联表查外键字段的操作

 

 查看执行的sql:

EFCore Study(四)——Select的应用及不走联表查外键字段的操作

 

 没有联表


 

上一篇:EFCore 读取json文件数据 写入数据库


下一篇:EFCore生产环境数据库升级方案