qq_33906407
qq_33906407
2016-02-01 07:57

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

  • ef
  • linq
  • net
  • 聚合函数

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条回答