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

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
...全文
127 13 打赏 收藏 转发到动态 举报
写回复
用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
内容概要:本文围绕基于风光储能和需求响应的微电网日前经济调度问题,提出了一种综合考虑风能、光伏等可再生能源出力不确定性、储能系统充放电特性以及需求响应机制的优化调度模型,并提供了完整的Python代码实现。该模型在满足系统功率平衡、设备运行约束等条件下,以最小化运行成本或最大化经济效益为目标,详细阐述了数学建模过程、目标函数构建、约束条件设定及求解算法的设计思路,具备较强的理论深度与工程实用性。所附代码结构清晰,便于复现与拓展,适用于科研学习与实际项目仿真验证。; 适合人群:具备一定电力系统基础知识和Python编程能力的高校学生、研究人员及从事新能源微电网相关工作的工程师。; 使用场景及目标:①用于教学与科研中深入理解微电网日前经济调度的核心原理与建模方法;②为实际微电网项目的调度决策提供算法支持与仿真工具;③作为进一步研究多能源协同优化、不确定性处理(如场景生成与削减)、鲁棒优化或分布鲁棒优化的基础框架。; 阅读建议:建议读者结合文中代码逐行调试运行,深入理解各模块功能与数据流向,同时可尝试修改模型参数、增加新的约束条件或引入其他智能优化算法进行对比分析,以提升对微电网优化调度问题的整体建模与求解能力。
源码直接下载地址: https://pan.quark.cn/s/95437fdf229e Intel I-219V网卡驱动是一款专门为Intel的I-219V千兆以太网控制器而研发的驱动程序,其主要作用在于保障在Ubuntu 16.04操作系统环境下的正常运作以及优化系统性能。Intel I-219V作为一款广泛应用的内置网络接口控制器(NIC),常被集成在台式机及笔记本电脑的主板上,负责提供高速的网络连接服务。Intel公司所提供的e1000e驱动是与此硬件相配套的开源驱动解决方案,其中版本3.3.5.3是专门针对该硬件设备的定制版本。此驱动包含了不可或缺的源代码部分,赋予开发者和系统管理者按照特定需求进行编译和定制的权限,从而能够适应多样化的系统配置或针对特定情形进行问题解决。源代码的可用性同样表明用户有能力依据Linux内核的更新情况来升级驱动,确保与最新技术标准的兼容性。在Ubuntu 16.04系统中成功编译的驱动意味着它已经通过了严苛的测试流程,并能够与该版本的Linux内核实现良好兼容。Ubuntu 16.04,其代号为Xenial Xerus,是一个长期支持(LTS)的版本,因此对于那些追求系统稳定性和安全保障的用户群体而言具有特殊的意义。驱动程序的兼容性保障了I-219V网卡能够在该系统平台上实现无缝运行,提供稳定可靠的网络连接,这既包括局域网(LAN)的连接,也可能涵盖通过Wi-Fi桥接实现的无线网络连接。驱动程序的核心职责涵盖了网络接口的初始化与管理、数据包的接收与发送处理,以及错误检测与纠正功能的执行。在Linux操作系统架构中,驱动通常以模块的形式加载至内核之中,这种设计允许在非必要时期进行卸载操作,以此来有效节省系统资源。e1000e驱...

57,064

社区成员

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

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