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;

 

转载于:https://www.cnblogs.com/njcxwz/p/5893211.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值