关于SQL语句的group by 以及如何 “先排序,再查询”

SELECT
message.msgid,
message.uid,
message.type,
message.msgtype,
message.msg,
message.time,
message.flowers
FROM
message
GROUP BY
message.uid,
message.type
ORDER BY
message.readed ASC,

message.time DESC;

这样一段代码;

一开始以为是查询time时间降序情况下的”uid与type不同的每组的一条“,后来发现是查询”uid与type不同的每组的一条“后,再对这些数据排序。

所查询到的是按msgid排序的每组的最后一条(我也不知道为什么是最后一条,可能因为msgid为自增长序列?)



那么如何得到按照时间降序排列的,每个uid和type组合的第一条数据呢?

方法一:

SELECT
message.msgid,
message.uid,
message.type,
message.msgtype,
message.msg,
message.time,
message.flowers,

MAX(message.time) AS max
FROM
message
GROUP BY
message.uid,
message.type
ORDER BY
message.readed ASC,

message.time DESC;

方法一使用MAX(time)甄别出每组中time最大的那条数据,自然就是我想要的数据了,尽管这个”max“没有什么实质性作用。


方法二:

SELECT
msgid,
uid,
type,
msgtype,
msg,
time,
flowers

FROM
(SELECT * from message ORDER BY time)
GROUP BY
message.uid,
message.type
ORDER BY
message.readed ASC,

message.time DESC;

方法二现将原表进行排序(默认ASC升序)

这样再去查询的时候默认留下最后一条数据自然就是time最大的那条啦!


具体的方法是在网上看来的,自己总结了一下~感谢愿意分享技术的程序员们~


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
SQL语句中,GROUP BY子句用于按照指定的列或表达式对查询结果进行分组。它将查询结果分为多个组,并对每个组应用聚合函数(如SUM,AVG,COUNT等)。注意,GROUP BY子句的执行顺序高于SELECT子句,因此SELECT子句中定义的列的别名不能在GROUP BY子句中使用。此外,GROUP BY子句的结果是随机的,没有特定的排序顺序。 在GROUP BY子句之,我们可以使用WHERE子句进行数据过滤。WHERE子句用于在分组之从结果集中筛选出满足特定条件的行。这意味着WHERE子句中不能包含聚合函数,它只能用于过滤行而不是分组。 举个例子,假设我们有一个名为test的表,包含name和id两列。我们想要按照name列进行分组,并计算每个组中id的和。我们可以使用以下SQL语句: SELECT name, SUM(id) FROM test GROUP BY name 这个语句将会按照name列进行分组,并计算每个组中id的和。注意,这里没有使用WHERE子句进行数据过滤,而是只使用了GROUP BY子句进行分组操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [SQLgroup by的用法总结](https://blog.csdn.net/u013242389/article/details/105331294)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [(转)SQLgroup by详解](https://blog.csdn.net/qq_41059320/article/details/89281125)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值