加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 实体框架与LINQ聚合连接字符串?

发布时间:2020-12-15 04:13:36 所属栏目:百科 来源:网络整理
导读:这对我来说很容易在TSQL中执行,但是我只是坐在这里把我的头撞在桌子上,试图让它在EF4中工作! 我有一张表,让它叫做TestData.它有字段,例如:DataTypeID,Name,DataValue. DataTypeID,DataValue1,"Data 1","Value1"1,"Value2"2,"Value3"3,"Value4" 我想对DataI
这对我来说很容易在TSQL中执行,但是我只是坐在这里把我的头撞在桌子上,试图让它在EF4中工作!

我有一张表,让它叫做TestData.它有字段,例如:DataTypeID,Name,DataValue.

DataTypeID,DataValue
1,"Data 1","Value1"
1,"Value2"
2,"Value3"
3,"Value4"

我想对DataID / Name进行分组,并将DataValue连接成CSV字符串.所需结果应包含 –

DataTypeID,DataValues
1,"Value1,Value2"
2,"Value4"

现在,我正在努力做到这一点 –

var query = (from t in context.TestData
  group h by new { DataTypeID = h.DataTypeID,Name = h.Name } into g
  select new
 {
   DataTypeID = g.Key.DataTypeID,Name = g.Key.Name,DataValues = (string)g.Aggregate("",(a,b) => (a != "" ? "," : "") + b.DataValue),}).ToList()

问题是LINQ to Entities不知道如何将它转换成SQL.这是3个LINQ查询的联合的一部分,我真的很喜欢它这样保持.我想我可以检索数据,然后再执行聚合.出于性能原因,这对我的应用程序无效.我也考虑使用SQL服务器功能.但是,EF4世界似乎并不“正确”.

任何人都在意这个破解?

解决方法

如果ToList()是您的原始查询的一部分,而不是仅为此示例添加,则在结果列表中使用LINQ to Objects进行聚合:
var query = (from t in context.TestData
            group t by new { DataTypeID = t.DataTypeID,Name = t.Name } into g 
            select new { DataTypeID = g.Key.DataTypeID,Data = g.AsEnumerable()})
            .ToList()
            .Select (q => new { DataTypeID = q.DataTypeID,Name = q.Name,DataValues = q.Data.Aggregate ("",(acc,t) => (acc == "" ? "" : acc + ",") + t.DataValue) });

在LINQPad中测试并产生此结果:

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读