SQL语句GROUP BY分组后取最新一条记录

MAX()函数和GROUP BY配合使用时,GROUP BY获取的数据永远是这个分组排序最上面的一条,MAX()函数会将这个分组中最大的值取出来,这样会导致查询出来的数据对应不上。

正确使用方法是:

SELECT
  a.property_id,
    a.annual,
    a.creade_grade 
FROM
    ad_creade_grade AS a 
WHERE
    a.last_time = ( SELECT max( b.last_time ) FROM ad_creade_grade b WHERE a.property_id = b.property_id ) 
GROUP BY
    a.annual,
    a.last_time 
ORDER BY
    a.last_time DESC

### SQL 分组每组一条记录 为了实现在SQL分组并获每组的一条记录,可以采用多种方法。具体实现决于所使用的数据库管理系统以及需求的具体细节。 #### 方法一:使用窗口函数 现代版本的大多数关系型数据库支持窗口函数,这使得操作变得更为简便。通过`ROW_NUMBER()`这样的窗口函数,可以在每一组内部创建一个按某些标准排序后的行号,从而方便选各组的第一条记录[^3]。 ```sql WITH RankedRecords AS ( SELECT *, ROW_NUMBER() OVER (PARTITION BY team_id ORDER BY pageviews DESC) as rn FROM your_table_name ) SELECT id, name, team_id, pageviews FROM RankedRecords WHERE rn = 1; ``` 此代码片段展示了如何利用`ROW_NUMBER()`为每个团队分配基于页面浏览量降序排列的独特编号,并最终筛选出具有最小行号(`rn=1`)即最高页面浏览量的那一项。 #### 方法二:子查询方式 如果不支持窗口函数,则可以通过自连接或者嵌套子查询的方式来达到相同的效果。这种方法通常效率较低,但在不支持高级特性的旧版DBMS上仍然适用[^4]。 ```sql SELECT t1.* FROM your_table_name t1 LEFT JOIN your_table_name t2 ON t1.team_id = t2.team_id AND (t1.pageviews < t2.pageviews OR (t1.pageviews = t2.pageviews AND t1.id < t2.id)) WHERE t2.id IS NULL; ``` 上述语句逻辑在于找到那些在其所属小组内没有任何其他成员拥有更大或相等(但ID更小)pageview值的记录;换句话说,这些正是我们要找寻的目标——每组中的最大者之一。 #### 方法三:聚合函数配合外键关联 当只需要某类特定字段而不需要完整的原始行时,可以直接运用聚合函数如MAX(), MIN()等结合GROUP BY完成任务。不过需要注意的是这种方式无法保留原表结构之外的信息[^1]。 ```sql SELECT MAX(id), NAME, team_id, MAX(pageviews) FROM your_table_name GROUP BY team_id, NAME; -- 假设name在team_id下唯一 ``` 以上三种方案提供了不同场景下的解决方案,选择哪种决于实际应用场景和个人偏好。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值