请教把三个 SELECT 操作整合到一个 SELECT 能解决的语句?

2020-08-27 19:34:53 +08:00
 qazwsxkevin
以前写的语句:
SELECT 生成时间 FROM result WHERE `型号`='1' ORDER BY 生成时间 DESC LIMIT 1;
SELECT 生成时间 FROM result WHERE `型号`='2' ORDER BY 生成时间 DESC LIMIT 1;
SELECT 生成时间 FROM result WHERE `型号`='3' ORDER BY 生成时间 DESC LIMIT 1;

生成时间是 datatime
程序拿到结果后,再本地算法算出最小(时间最早的值)
请问如果在 Mysql 语句上,如何实现一句出结果呢?
`型号`='3'很有可能没有存在。。。
3315 次点击
所在节点    MySQL
24 条回复
coderfox
2020-08-28 09:47:54 +08:00
@coderfox #20 更正一下,只需要 SELECT 型号, MAX(生成时间) FROM test WHERE 型号 IN ('1', '2', '3') GROUP BY 型号;
jzmws
2020-08-28 09:54:53 +08:00
考虑用 case ?
bigpower777
2020-08-28 16:54:46 +08:00
SELECT
s1.d1,
s2.d2,
s3.d3
FROM
(select CREATE_DATE as d1 from account_system where MZ='01' ORDER BY CREATE_DATE desc limit 1) s1,
(select CREATE_DATE as d2 from account_system where MZ='02' ORDER BY CREATE_DATE desc limit 1) s2,
(select CREATE_DATE as d3from account_system where MZ='03' ORDER BY CREATE_DATE desc limit 1) s3
gaius
2020-08-28 19:40:37 +08:00
pg 或者 mysql8 用窗口函数

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/702006

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX