LINQ to Entities GroupBy之后不能用Distinct?

ylynet 2016-10-07 05:03:54
 var result = q.GroupBy(g => g.CREATE_USER).Select(s => new
{
userName = s.Key,
count =s.Select(se=>se.PURCHASE_ITEM.PRODUCT_ID).Distinct().Count(),
quantity = s.Sum(ss => ss.TRANSFER_QUANTITY)
});

去掉 Distinct就没问题
...全文
475 10 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
syeerzy 2016-10-13
  • 打赏
  • 举报
回复
如果是这个错误信息, 我猜想生成的sql并不是最优的, 可能是distinct和count是套在两层里, 以至于在AS 成其他名字的时候, 没对正位置, 你试试: var result = q.GroupBy(g => g.CREATE_USER).Select(s => new { CREATE_USER = s.Key, count =s.Select(se=>se.PURCHASE_ITEM.PRODUCT_ID).Distinct().Count(), quantity = s.Sum(ss => ss.TRANSFER_QUANTITY) }); 就是把userName 用真正的字段名, 看看是否就没错了
q107770540 2016-10-11
  • 打赏
  • 举报
回复
error message is clearly enough, so delete the edmx file and generate it from latest database again
ylynet 2016-10-11
  • 打赏
  • 举报
回复
引用 7 楼 DragonerHuang 的回复:
[quote=引用 5 楼 ylynet 的回复:] [quote=引用 1 楼 syeerzy 的回复:] 用 Distinct 报了什么错? 按理应该是可以的(至少Linq to Sql 可以, LINQ to Entities好像没什么特别理由拒绝这种写法) 或者你的Entities背后的数据库不支持 count(distinct __) ?
ORA-00904: "Project1"."CREATE_USER": 标识符无效[/quote] 这个要么是没有这个字段,要么就是这个linq出来的语句有错误,或者你的语句得出的结果有危险字符[/quote] GroupBy 这个字段的。。。
ylynet 2016-10-11
  • 打赏
  • 举报
回复
引用 6 楼 q107770540 的回复:
error message is clearly enough, so delete the edmx file and generate it from latest database again
没用的 去掉distinct 就好了。不知道什么原因 最后还是 自定义一个对象 循环GroupBy 赋值 解决
DragonerHuang 2016-10-11
  • 打赏
  • 举报
回复
引用 5 楼 ylynet 的回复:
[quote=引用 1 楼 syeerzy 的回复:] 用 Distinct 报了什么错? 按理应该是可以的(至少Linq to Sql 可以, LINQ to Entities好像没什么特别理由拒绝这种写法) 或者你的Entities背后的数据库不支持 count(distinct __) ?
ORA-00904: "Project1"."CREATE_USER": 标识符无效[/quote] 这个要么是没有这个字段,要么就是这个linq出来的语句有错误,或者你的语句得出的结果有危险字符
ylynet 2016-10-10
  • 打赏
  • 举报
回复
引用 1 楼 syeerzy 的回复:
用 Distinct 报了什么错? 按理应该是可以的(至少Linq to Sql 可以, LINQ to Entities好像没什么特别理由拒绝这种写法) 或者你的Entities背后的数据库不支持 count(distinct __) ?
ORA-00904: "Project1"."CREATE_USER": 标识符无效
ylynet 2016-10-10
  • 打赏
  • 举报
回复
引用 3 楼 q107770540 的回复:
 count =s.Select(se=>se.PURCHASE_ITEM.PRODUCT_ID).Distinct().Count(),
if se.PURCHASE_ITEM is null, then you cannot get the PRODUCT_ID. so can you try this:
 count =s.Where(se=>se.PURCHASE_ITEM !=null).Select(se=>se.PURCHASE_ITEM.PRODUCT_ID).Distinct().Count(),
引用 3 楼 q107770540 的回复:
 count =s.Select(se=>se.PURCHASE_ITEM.PRODUCT_ID).Distinct().Count(),
if se.PURCHASE_ITEM is null, then you cannot get the PRODUCT_ID. so can you try this:
 count =s.Where(se=>se.PURCHASE_ITEM !=null).Select(se=>se.PURCHASE_ITEM.PRODUCT_ID).Distinct().Count(),
加上条件也一样报错 ORA-00904: "Project1"."CREATE_USER": 标识符无效
threenewbee 2016-10-08
  • 打赏
  • 举报
回复
groupby后select key就是了,不用distinct
q107770540 2016-10-08
  • 打赏
  • 举报
回复
 count =s.Select(se=>se.PURCHASE_ITEM.PRODUCT_ID).Distinct().Count(),
if se.PURCHASE_ITEM is null, then you cannot get the PRODUCT_ID. so can you try this:
 count =s.Where(se=>se.PURCHASE_ITEM !=null).Select(se=>se.PURCHASE_ITEM.PRODUCT_ID).Distinct().Count(),
syeerzy 2016-10-07
  • 打赏
  • 举报
回复
用 Distinct 报了什么错? 按理应该是可以的(至少Linq to Sql 可以, LINQ to Entities好像没什么特别理由拒绝这种写法) 或者你的Entities背后的数据库不支持 count(distinct __) ?

62,242

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧