示例:
这是一张记录人员来访的记录表。
数据表里的数据准确记录了每个人来访时带的帽子颜色、时间、人员编码(每个人唯一)。
数据样例:
需要查询符合条件的最新的来访记录。
先展示错误的sql示例:想当然的使用max()函数。
SELECT MAX(id) AS id ,user_code,cap_color,create_time FROM vist_record WHERE user_code='A101' ;
查询结果(错误结果):
按照条件筛选后,取了符合条件的最大的一个id值,单独替换了id,查询结果错误。
正确的数据是:
max()函数正确用法:
SELECT
id,user_code,cap_color,create_time
FROM vist_record
WHERE id IN (SELECT MAX(id) AS id FROM vist_record WHERE user_code='A101' )
查询结果:
方法二:
如果我们确定id是自增的,id最大的数据(符合条件的数据)就是最新的。
那么我们就可以使用倒序DESC来取最新数据。
使用倒序查询:
SELECT *
FROM vist_record
WHERE user_code='A101'
ORDER BY id DESC
LIMIT 1;
查询结果:
或者根据时间倒序:
SELECT *
FROM vist_record
WHERE user_code='A101'
ORDER BY create_time DESC
LIMIT 1;
查询结果:
如果需求要的不是指定A101要的是涉及到的每一个人的最新数据呢?
也就是存在多组的概念。
每一类的符合条件的最新数据。
橙色框就是 A101 、B202 、 C303 分别的最新记录 , 我们要取出来。
错误示例:
SELECT MAX(id) AS id ,user_code,cap_color,create_time FROM vist_record GROUP BY user_code
错误的筛选结果:
正确SQL:
SELECT id ,user_code,cap_color,create_time FROM vist_record WHERE id in
(
SELECT MAX(id) AS id FROM vist_record GROUP BY user_code
)