一、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);
查看执行的sql:
没有联表