一、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:
没有联表
分类:
EF/EF Core
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?