MYSQL:选择每个组每个组的最晚日期

MYSQL: SELECT latest date per group per group

提问人:Ryflex 提问时间:11/2/2023 最后编辑:Ryflex 更新时间:11/2/2023 访问量:37

问:

我有一个脑筋急转弯。 我已经四处搜索了,但我找到的所有东西都可以找到 1 组的最新内容。不是组中的组。

我有一个包含以下标题的表:

身份证 |车辆编号 |清洁类型 |日期

每个 ID 都是唯一的。大约有 25 种不同的车辆 ID 可以在那里停留超过 1 次。有3种类型的清洁,当然还有日期。 这个想法是,每次车辆进行清洁时,都会将其记录在新记录中。示例:110 号车辆在 10 月 1 日进行内部清洁。 如果我在 10 月 25 日对 110 号车进行另一次内部清洁,则会添加一条新记录,因此我们有一个记录所有清洁的数据库。

为了快速查看每种类型的清洁都清洁了哪辆车,我需要 1 个查询,它给了我一个数组,告诉我车辆编号、类型和最新日期。

我尝试了不同的选择,最接近的是我得到的:

SELECT * 
FROM cleanings
GROUP BY vehicle_id, type
ORDER BY vehicle_id ASC, date DESC;

这给出了每种类型、每辆车的第一次清洁日期,这主要是最早的日期。

示例数据:

INSERT INTO `cleanings` (`id`, `vehicle_id`, `employees_id`, `type`, `date`, `created`, `modified`) VALUES
(1, 15103, 1, 'Buitenkant', '2023-10-06', '2023-10-08 06:44:22', '2023-10-09 18:50:08'),
(2, 15103, 2, 'Buitenkant', '2023-10-08', '2023-10-08 06:44:34', '2023-10-09 18:54:25'),
(3, 15102, 2, 'Buitenkant', '2023-10-03', '2023-10-09 14:15:34', '2023-10-09 18:43:24'),
(4, 15101, 1, 'Buitenkant', '1989-11-10', '2023-10-09 14:22:53', '2023-10-09 17:35:17'),
(5, 15110, 2, 'Buitenkant', '2022-10-19', '2023-10-09 18:49:59', '2023-10-13 14:12:24'),
(6, 15110, 1, 'Buitenkant', '2022-10-18', '2023-10-08 04:44:22', '2023-10-13 14:12:17'),
(7, 15109, 2, 'Binnenkant', '2023-10-08', '2023-10-08 04:44:34', '2023-10-09 18:52:16'),
(8, 15116, 2, 'Binnenkant', '2023-10-03', '2023-10-09 12:15:34', '2023-10-09 18:52:16'),
(9, 15118, 1, 'Binnenkant', '1989-11-10', '2023-10-09 12:22:53', '2023-10-09 18:52:16'),
(10, 15119, 2, 'Binnenkant', '2023-10-19', '2023-10-09 16:49:59', '2023-10-09 18:52:16'),
(11, 15101, 1, 'Saniswiss', '2023-10-06', '2023-10-08 04:44:22', '2023-10-13 08:16:48'),
(12, 15103, 2, 'Saniswiss', '2023-10-08', '2023-10-08 04:44:34', '2023-10-09 18:52:59'),
(13, 15116, 2, 'Saniswiss', '2023-10-03', '2023-10-09 12:15:34', '2023-10-09 18:52:59'),
(14, 15111, 1, 'Saniswiss', '1989-11-10', '2023-10-09 12:22:53', '2023-10-09 18:52:59'),
(15, 15112, 2, 'Saniswiss', '2023-10-19', '2023-10-09 16:49:59', '2023-10-09 18:52:59'),
(16, 15105, 1, 'Buitenkant', '2023-10-09', '2023-10-09 18:58:33', '2023-10-09 18:58:33'),
(17, 15105, 2, 'Binnenkant', '2023-10-06', '2023-10-09 20:38:00', '2023-10-16 22:51:17'),
(18, 15112, 2, 'Binnenkant', '2023-12-12', '2023-10-16 22:51:32', '2023-10-16 22:51:32'),
(19, 15590, 15, 'Saniswiss', '2024-01-01', '2023-10-17 12:35:48', '2023-10-30 21:02:02'),
(21, 15101, 1, 'Buitenkant', '2023-10-20', '2023-10-17 14:46:29', '2023-10-17 14:46:29'),
(29, 15107, 15, 'Buitenkant', '2023-11-24', '2023-11-01 11:34:28', '2023-11-01 11:34:28'),
(30, 15215, 14, 'Saniswiss', '2023-11-20', '2023-11-01 11:35:32', '2023-11-01 11:35:32'),
(31, 15213, 1, 'Buitenkant', '2023-11-01', '2023-11-01 11:35:41', '2023-11-01 11:35:41'),
(32, 15118, 1, 'Binnenkant', '2023-11-02', '2023-11-02 10:02:51', '2023-11-02 10:02:51'),
(33, 15118, 1, 'Binnenkant', '2023-11-02', '2023-11-02 10:03:21', '2023-11-02 10:03:21'),
(34, 15118, 1, 'Buitenkant', '2023-11-02', '2023-11-02 10:05:08', '2023-11-02 10:05:08'),
(35, 15101, 1, 'Buitenkant', '2023-11-02', '2023-11-02 10:55:38', '2023-11-02 10:55:38');

查询结果示例:

array (size=21)
  0 => 
    array (size=7)
      'id' => int 4
      'vehicle_id' => int 15101
      'employees_id' => int 1
      'type' => string 'Buitenkant' (length=10)
      'date' => string '1989-11-10' (length=10)
      'created' => string '2023-10-09 16:22:53' (length=19)
      'modified' => string '2023-10-09 19:35:17' (length=19)
  1 => 
    array (size=7)
      'id' => int 11
      'vehicle_id' => int 15101
      'employees_id' => int 1
      'type' => string 'Saniswiss' (length=9)
      'date' => string '2023-10-06' (length=10)
      'created' => string '2023-10-08 06:44:22' (length=19)
      'modified' => string '2023-10-13 10:16:48' (length=19)
  2 => 
    array (size=7)
      'id' => int 3
      'vehicle_id' => int 15102
      'employees_id' => int 2
      'type' => string 'Buitenkant' (length=10)
      'date' => string '2023-10-03' (length=10)
      'created' => string '2023-10-09 16:15:34' (length=19)
      'modified' => string '2023-10-09 20:43:24' (length=19)

示例最终结果:Sample result

mysql 选择

评论

0赞 O. Jones 11/2/2023
通常,提出类似问题的人会以文本形式包括其表格的示例数据和所需结果的示例。请编辑您的问题。
1赞 Rob Eyre 11/2/2023
这看起来像是一个常见问题的变体 - 包含特定列的按组最大值的行。有关不同方法的摘要,请参见 dev.mysql.com/doc/refman/8.0/en/...
0赞 Ryflex 11/2/2023
@O.Jones 已编辑更多信息
0赞 Ryflex 11/2/2023
@RobEyre 编辑了为什么这不起作用。基本上,我发现每个“解决方案”都是关于每个分组的最新日期。我的问题是分组中的分组,然后是最新的日期。

答:

1赞 Rob Eyre 11/2/2023 #1

https://dev.mysql.com/doc/refman/8.0/en/example-maximum-column-group-row.html 的角度来看,沿着这些思路的东西可能会给你带来你正在寻找的结果。连接条件意味着对于每一行,我们为相同的车辆和类型寻找另一行,但日期较晚。然后,该子句强制执行不应有此类匹配行的条件(仅当该行已经是车辆和类型组合的最新行时,才为真)LEFT JOINWHERE

SELECT c1.* 
FROM cleanings c1
LEFT JOIN cleanings c2 ON
  c1.vehicle_id = c2.vehicle_id
  AND c1.type = c2.type
  AND c2.date > c1.date
WHERE c2.ID IS NULL
ORDER BY c1.vehicle_id ASC, c1.date DESC;

评论

0赞 Ryflex 11/2/2023
感谢您提供此解决方案。它按应有的方式运行。