mysql - 如何快速从关系 mysql 表中选择最大值(时间戳)
问题描述
我们正在开发一个工单系统,我们希望在仪表板上显示工单的最新状态。我们有两张桌子。第一个用于工单本身,第二个用于单个编辑。
系统已经在运行,但是仪表板的性能很差(大约 1300 张票需要 6 秒)。起初,我们使用了一个声明,它为每张票选择了 'where timestamp = (select max(Timestamp))'。在第二步中,我们创建了一个仅包含每张工单的最新时间戳的视图,但我们无法在此视图中也包含正确的状态。
所以主要的问题可能是,我们不能建立一个表格,在其中为每张票选择最新的 ins_date和最新的状态。
简化的数据库如下所示:
CREATE TABLE `ticket` (
`id` int(10) NOT NULL,
`betreff` varchar(100) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
CREATE TABLE `ticket_relation` (
`id` int(11) NOT NULL,
`ticket` int(10) NOT NULL,
`info` varchar(10000) DEFAULT NULL,
`status` int(1) NOT NULL DEFAULT '0',
`ins_date` timestamp NULL DEFAULT CURRENT_TIMESTAMP,
`ins_user` int(11) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
INSERT INTO `ticket` (`id`, `betreff`) VALUES
(1, 'Technische Frage'),
(2, 'Ticket 2'),
(3, 'Weitere Fragen');
INSERT INTO `ticket_relation` (`id`, `ticket`, `info`, `status`, `ins_date`, `ins_user`) VALUES
(1, 1, 'Betreff 1', 0, '2019-05-28 11:02:18', 123),
(2, 1, 'Betreff 2', 3, '2019-05-28 12:07:36', 123),
(3, 2, 'Betreff 3', 0, '2019-05-29 06:49:32', 123),
(4, 3, 'Betreff 4', 1, '2019-05-29 07:44:07', 123),
(5, 2, 'Betreff 5', 1, '2019-05-29 07:49:32', 123),
(6, 2, 'Betreff 6', 3, '2019-05-29 08:49:32', 123),
(7, 3, 'Betreff 7', 2, '2019-05-29 09:49:32', 123),
(8, 2, 'Betreff 8', 1, '2019-05-29 10:49:32', 123),
(9, 3, 'Betreff 9', 2, '2019-05-29 11:49:32', 123),
(10, 3, 'Betreff 10', 3, '2019-05-29 12:49:32', 123);
我创建了一个 SQL Fiddle:http ://sqlfiddle.com/#!9/a873b6/ 3 前三个语句是无法正常工作或太慢的尝试。最后一个是我认为的关键,但我不明白,为什么这会导致状态错误。
尝试为每张工单创建具有最新 ins_date 和状态的表:
SELECT
ticket, status, MAX(ins_date) as max_date
FROM
ticket_relation
GROUP BY
ticket
ORDER BY
ins_date DESC;
此查询获取每张工单的正确(最新)ins_date,但不是最新状态:
+--------+--------+----------------------+
| ticket | status | max_date |
+--------+--------+----------------------+
| 3 | 1 | 2019-05-29T12:49:32Z |
+--------+--------+----------------------+
| 2 | 0 | 2019-05-29T10:49:32Z |
+--------+--------+----------------------+
| 1 | 0 | 2019-05-28T12:07:36Z |
+--------+--------+----------------------+
预期的输出是这样的:
+--------+--------+----------------------+
| ticket | status | max_date |
+--------+--------+----------------------+
| 3 | 3 | 2019-05-29T12:49:32Z |
+--------+--------+----------------------+
| 2 | 1 | 2019-05-29T10:49:32Z |
+--------+--------+----------------------+
| 1 | 3 | 2019-05-28T12:07:36Z |
+--------+--------+----------------------+
有没有一种有效的方法来为票表中的每张票选择最新的时间戳和状态?
解决方案
您可以尝试以下查询 -
SELECT
ticket, status, ins_date as max_date
FROM ticket_relation a
where ins_date in (select max(ins_date) from ticket_relation b where a.ticket=b.ticket)
推荐阅读
- angular - 当我们从路径移动到另一个路径时如何保持 Angular 8 应用程序状态
- javascript - 动画未显示,动画在屏幕上移动时正在复制
- 3d - 圆锥尖端的法线
- r - 使用 R 的线性回归模型
- javascript - jQuery mouseenter & click 事件
- r - DT::renderTable() 显示“未找到匹配记录”和“显示 0 到 0 个条目(从 x 个总条目过滤)”
- python - 使用 urllib2 从 Internet 下载文件
- ruby-on-rails - 当我将 Ruby on Rails 模型的 AWS URL 包含在关联模型的 GET 请求中时,我错过了它
- c# - 从资源中加载文本框的光标
- java - 用对象填充空数组