zoukankan      html  css  js  c++  java
  • 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;

  • 相关阅读:
    php 基础------数组过滤
    js或者jq 使用cookie 时在谷歌浏览器不好使
    css3 -阻止元素成为鼠标事件目标 pointer-events
    CSS3-----transform 转换
    css3---过渡
    css3动画----animation
    移动端尺寸适配--媒体查询
    工作一年总结
    关于Jquery.Data()和HTML标签的data-*属性
    android shape
  • 原文地址:https://www.cnblogs.com/njcxwz/p/5893211.html
Copyright © 2011-2022 走看看