5

group by的示例-在网上使用linq计数选择最小日期,但我找不到针对我的问题的特定解决方案。而且我没有先进的 linq 理解来组合我迄今为止发现的这些解决方案。

我有一个这样的 SQL 查询:

select client_id 
from my_table /* Column1 : client_id, Column2 : _month */
group by client_id
having min(_month) = '2009-11'

我的问题是:如何将此查询转换为 c# linq?. 到目前为止,我写了这样的东西,但它并没有给出我必须拥有的东西:

var query = dataTable.AsEnumerable() // This is my_table
  .GroupBy(c => c.Field<Int32>("client_id"))
  .Select(g => new
  {
      g.Key,
      minMonth = g.Min(c => c.Field<string>("_month"))
  })
  .Where(d => d.minMonth == "Some String like '2009-11'");   

它实际上给了我不需要的这个 SQL 的结果:

select client_id, min(_month) 
from my_table 
where _month = '2009-11' 
group by client_id

注意:_month 是一个格式为 YYYY-MM 的字符串。

4

1 回答 1

6

尝试这个:

var results = mytable.GroupBy(x => x.client_id)
                     .Where(x => x.Min(y => DateTime.ParseExact(y._month,"yyyy-MM",null))
                                   == new DateTime(2009,11,1))
                     .Select(x=>x.Key);

having子句Where在此 LINQ 语句中实现。分组后client_id,我们使用x.Min来实现min聚合函数_month,然后使用ParseExact解析为年月组合的方法进行比较。

从OP 提供的SQLFiddle中,返回了 4 条记录。使用相同数据的演示和上述查询也返回相同的 4 条记录。

于 2014-07-21T03:18:14.640 回答