查出上传时间最晚的 记录 并按用户分组

phoenix_pj 2009-09-01 02:38:52
这是我的photo表的结构
CREATE TABLE `photo` (
`id` bigint(20) NOT NULL,
`uptime` datetime default NULL,
`user_id` bigint(20) NOT NULL,
PRIMARY KEY (`id`),
KEY `FK65B3E3248CE7A33` (`user_id`),

CONSTRAINT `FK65B3E3248CE7A33` FOREIGN KEY (`user_id`) REFERENCES `user` (`id`),

)

我想从photo表中找到 以userid分组的,且上传时间最晚的记录
也就是查出来每个user 最新上传的photo
...全文
78 13 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
13 条回复
切换为时间正序
请发表友善的回复…
发表回复
phoenix_pj 2009-09-01
  • 打赏
  • 举报
回复
好了,谢谢各位了
vinsonshen 2009-09-01
  • 打赏
  • 举报
回复
看你的表结构,应该你的photo表类似一个日志表,所以,上传时间最晚的记录也就是ID值最大的记录:

写法1:
select a.*,b.* from photo a,`user` b where a.user_id=b.id and not exists (
select 1 from photo c where c.user_id=a.user_id and c.id>a.id);

写法2:
select a.*,b.* from photo a,`user` b where a.user_id=b.id and a.id=(select max(c.id) from photo c where c.user_id=a.user_id);

写法3:
select a.*,b.* from photo a,`user` b,(select user_id,max(id) as newid from photo group by user_id) c where a.user_id=b.id and a.id=c.newid;
wwwwb 2009-09-01
  • 打赏
  • 举报
回复
贴记录及要求结果出来看看
select a.id,a.uptime,a.user_id from photo a
left join photo b on a.userid=b.userid and a.uptime<=b.uptime
group by a.id,a.uptime,a.user_id having count(b.id)=1
ACMAIN_CHM 2009-09-01
  • 打赏
  • 举报
回复


建议你列出你的表结构,并提供测试数据以及基于这些测试数据的所对应正确结果。
phoenix_pj 2009-09-01
  • 打赏
  • 举报
回复
谢谢善良的你,我试了下会有重复,而且,DISTINCT去不掉
nianzhang747 2009-09-01
  • 打赏
  • 举报
回复
贴出数据来看看 是不是你的数据有问题

max(datetime)能查出最大记录


ACMAIN_CHM 2009-09-01
  • 打赏
  • 举报
回复
类似问题这个版块中经常出现。
phoenix_pj 2009-09-01
  • 打赏
  • 举报
回复
高手!为什么这么快?你经常查这种的 吗?
ACMAIN_CHM 2009-09-01
  • 打赏
  • 举报
回复
如果数据不多的话,也可以直接
select * 
from photo a
where not exists (select 1 from photo where user_id=a.user_id and uptime>a.uptime)
ACMAIN_CHM 2009-09-01
  • 打赏
  • 举报
回复
或者你也可以用inner join 这种格式,结果应该是一样
select photo.*
from photo inner join (select user_id,max(uptime) as max_uptime from photo group by user_id) p
on photo.user_id=p.user_id and photo.uptime=p.max_uptime
ACMAIN_CHM 2009-09-01
  • 打赏
  • 举报
回复
不会啊,一楼的应该是uptime 最大的那条啊。
phoenix_pj 2009-09-01
  • 打赏
  • 举报
回复
我查出来的结果虽然按user分组了,但是 不是最新的那条记录
ACMAIN_CHM 2009-09-01
  • 打赏
  • 举报
回复
select photo.*
from photo,(select user_id,max(uptime) as max_uptime from photo group by user_id) p
where photo.user_id=p.user_id
and photo.uptime=p.max_uptime

56,940

社区成员

发帖
与我相关
我的任务
社区描述
MySQL相关内容讨论专区
社区管理员
  • MySQL
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧