MySQL SELECT 唯一列,其中其他列是最大的

2023-12-08

我有这样的桌子

  id     |     serial_num     |      version     | .....
  1      |         1          |          1       | .....
  2      |         2          |          1       | .....
  3      |         2          |          2       | .....
  4      |         3          |          1       | .....
  5      |         4          |          1       | .....
  6      |         5          |          1       | .....
  7      |         5          |          2       | .....
  8      |         5          |          3       | .....

现在我要选择的是获取具有最大版本和唯一serialn_num 的行...

结果将是:

  id     |     serial_num     |      version     | .....
  1      |         1          |          1       | .....
  3      |         2          |          2       | .....
  4      |         3          |          1       | .....
  5      |         4          |          1       | .....
  8      |         5          |          3       | .....

我的 SQL 有点复杂,这就是为什么我不使用 MAX() 解决问题...我几乎没有左连接等...

有任何想法吗?

谨致问候并感谢您抽出宝贵时间!


尝试这个:

SELECT yourtable.*
FROM yourtable
WHERE (serial_num, version) in (select serial_num, max(version)
                                from yourtable
                                group by serial_num)

子查询将返回serial_num的最大版本,因此这将返回serial_num具有最大值的所有行。看这把小提琴.

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

MySQL SELECT 唯一列,其中其他列是最大的 的相关文章

随机推荐