旧日幻像 2016-02-01 07:57 采纳率: 0%
浏览 2287

Linq 多列求和 列是动态的 能不能不写sql就实现需求?

select sum(column1),sum(column2)... from tbl 这样一个sql 转化成 linq 要怎么写?
列是动态的 代码执行的时候才知道要对那些列求和。
不知道用linq怎么写 现在只能通过SqlQuery查询结果 使用System.Reflection.Emit 动态创建一个对应的类型装载结果 求教大神 有没有可能通过linq实现?

string sqlSelect = "";
                TypeBuilder builder = DatabaseExtensions.CreateTypeBuilder("MyDynamicAssembly", "MyModule", "MyType");
                facs.ForEach(k =>
                {
                    sqlSelect += "round(nvl(sum(" + k.DataColumn + "),0),2) as " + k.DataColumn + ",";
                    DatabaseExtensions.CreateAutoImplementedProperty(builder, k.DataColumn, typeof(decimal?));
                });
                Type resultType = builder.CreateType();
                var result = Dal.Database.SqlQuery(resultType, "select " + sqlSelect.TrimEnd(',') + "  from tbl " + sqlWhere, parms.ToArray());
  • 写回答

2条回答 默认 最新

  • threenewbee 2016-02-01 23:37
    关注

    如果你的数据量比较小,可以ToList全部取出来,然后再反射。

    如果数据量大,那么需要用表达式树来动态构造查询。但是直接用sql更简单。

    评论

报告相同问题?

悬赏问题

  • ¥15 乘性高斯噪声在深度学习网络中的应用
  • ¥15 运筹学排序问题中的在线排序
  • ¥15 关于docker部署flink集成hadoop的yarn,请教个问题 flink启动yarn-session.sh连不上hadoop,这个整了好几天一直不行,求帮忙看一下怎么解决
  • ¥30 求一段fortran代码用IVF编译运行的结果
  • ¥15 深度学习根据CNN网络模型,搭建BP模型并训练MNIST数据集
  • ¥15 C++ 头文件/宏冲突问题解决
  • ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
  • ¥50 安卓adb backup备份子用户应用数据失败
  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛
  • ¥30 python代码,帮调试,帮帮忙吧