EF获取一个或者多个字段
有时候直接查询出一个实体,比较浪费性能,对于字段比较少的表来说差异不大,但是如果一个表有几十个字段,你只要取出一个字段或者几个字段,而取出整个实体,性能就会有差异了。
/// <summary> /// 直接获取特定一个或者多个字段的值 /// 多个字段需要声明Model /// </summary> /// <typeparam name="T"></typeparam> /// <param name="predicate"></param> /// <param name="scalar"></param> /// <returns></returns> public T GetScalar<T>(Expression<Func<TEntity, bool>> predicate,Expression<Func<TEntity, T>> scalar) { if (predicate == null) { return dbContext.Set<TEntity>().AsNoTracking().Select(scalar).FirstOrDefault(); } else { return dbContext.Set<TEntity>().AsNoTracking().Where(predicate).Select(scalar).FirstOrDefault(); } }
单个字段就比较简单了
var s= testDal.GetScalar<string>(m=>m.Code== "02018",m=>m.Name);
多个字段需要定义Model
var s= testDal.GetScalar<StoreM>(m=>m.Code== "02018",m=>new StM { Name1= m.Name, Code=m.Code });
是不是很方便?
但是如果我们觉得定时Model比较麻烦,没关系 我们可以采用dynamic
var s= testDal.GetScalar<dynamic>(m=>m.Code== "02018",m=>new { m.Name,m.Code });
var a = s.Name;
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
· AI Agent开发,如何调用三方的API Function,是通过提示词来发起调用的吗