那么如何解决使分组后的数据按照主键的 desc 排序输出呢?
答案有两种方法:
1、使用子查询先把表进行排序,然后对字表进行 group by 查询,此时得到的列将是子查询的得到的一条记录的列。
2、使用 max 函数对可计算最大值的列进行对比查询,这种方法将只能使的对比列按照 desc 输出,不影响其他列。
以上两种方法的结果不同,使用的时候要按需来使用。
附例子:
表 tab1 有 3 列:主键id、名称name、登录时间time
id name time
1 a01 1
2 www.111com.net 2
3 a03 3
4 a02 4
5 a01 5
6 a04 6
需求:
1、要求查询出各用户的登陆次数和最后登陆时间
解决办法:
第一种方法
select sub.name,count(sub.id) as login_nums,sub.time as last_time
from (select * from tab1 order by time) sub
group by sub.name
注意:此时查询得到的每一个列都属于原表的同一行记录,如指定查询 id,则 id 也是最新时间那行记录的id 111com.net
第二种方法
select name,count(id) as login_nums,max(time) as last_time
from tab1
group by name
注意此时查询得到的每个列已经不再属于原表的同一行记录了。
电神魔傀2街机免费版 官方版v1.2.1
下载三国战纪2手游腾讯渠道服 安卓版v2.41.0.0
下载三国战纪2手游抖音渠道服 安卓版v2.41.0.0
下载三国战纪2折扣服 安卓版v2.41.0.0
下载叫我大掌柜小米版 安卓版v7.4.4
叫我大掌柜小米版是这款模拟经营类手游的渠道服版本,在此版本中
cooking fever正版 安卓最新版v23.0.2
cooking fever正版是一款非常好玩的模拟经营类手游
咖啡厅的生活故事 最新版v1.7
咖啡厅的生活故事是一款模拟经营游戏,玩家们在游戏中可以经营一
迅猛龙模拟器金币不减反增版 v1.1.8
迅猛龙模拟器无限金币版是一款动物模拟类游戏,玩家们将在游戏中
泽塔奥特曼升华器免广告版 v1.4
泽塔奥特曼升华器去广告版是游戏的破解版本,在该版本中为玩家去