MySQL查询最大值、最小值所在行
0.MySQL中可以使用max()函数来查询某一列的最大值。这里要解决的问题就是:
查询最大值所在行的数据。
1.数据准备:
我们创建了一张打卡记录表,表中属性分别是:主键id,打卡人员的姓名,各自的打卡时间。建表语句如下:
DROP TABLE IF EXISTS `t_record`;
CREATE TABLE `t_record` (
`n_id` bigint(20) NOT NULL AUTO_INCREMENT,
`c_name` varchar(255) DEFAULT NULL COMMENT '打卡人姓名',
`n_time` bigint(20) DEFAULT NULL COMMENT '打卡时间戳',
PRIMARY KEY (`n_id`)
);
模拟数据如下:
2.第一个场景:我想查询出来最晚打卡时间所在行的数据;
select * from t_record order by n_time desc limit 1;
3.第二个场景:我想查询每个人的最晚打卡时间所在行的数据:
SELECT
r2.*
FROM
(
SELECT
n_id, n_time
FROM
t_record
GROUP BY
c_name
) r1
LEFT JOIN t_record r2 ON r2.n_id = r1.n_id
版权声明:本文为TP89757原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。