qq_33906407
2016-02-01 07:57Linq 多列求和 列是动态的 能不能不写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条回答
为你推荐
- ASP.NET使用LINQ to SQL实现查询功能?
- c#
- visual studio
- asp.net
- 2个回答
- LINQ语言的方法,同时对2个字段排序怎么实现的呢?要详细一些
- 开发语言
- 1个回答
- .net3.5到底可以支持linq to sql吗?
- c#
- visual studio
- 1个回答
- LINQ TO SQL 多字段 查询 c#
- sql
- c语言
- c++
- 1个回答
- SQL server VS2015 怎么弄在一起
- sql
- c#
- linq
- 5个回答
换一换