我有以下查询:
SELECT timestamp,
COUNT(*)
FROM table
GROUP BY timestamp
但是有些时间戳没有显示,因为没有数据。这是一个例子
1:00:00 | 3
1:00:02 | 17
1:00:03 | 2
请注意,缺少 1:00:01。有没有办法让1:00:01 | 0
结果中出现?
我有以下查询:
SELECT timestamp,
COUNT(*)
FROM table
GROUP BY timestamp
但是有些时间戳没有显示,因为没有数据。这是一个例子
1:00:00 | 3
1:00:02 | 17
1:00:03 | 2
请注意,缺少 1:00:01。有没有办法让1:00:01 | 0
结果中出现?
MySQL 没有递归功能,因此您只能使用 NUMBERS 表技巧 -
创建一个只包含递增数字的表 - 使用 auto_increment 很容易做到:
DROP TABLE IF EXISTS `example`.`numbers`;
CREATE TABLE `example`.`numbers` (
`id` int(10) unsigned NOT NULL auto_increment,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
使用以下方法填充表:
INSERT INTO NUMBERS
(id)
VALUES
(NULL)
...根据需要获取尽可能多的值。
使用DATE_ADD构造时间列表,根据 NUMBERS.id 值增加秒数:
SELECT x.*
FROM (SELECT DATE_FORMAT(DATE_ADD('2010-01-01', INTERVAL n.id - 1 SECOND), '%T')
FROM numbers n) x
根据时间部分向您的数据表 LEFT JOIN:
SELECT x.ts AS timestamp,
COALESCE(COUNT(y.timestamp), 0) AS cnt
FROM (SELECT DATE_FORMAT(DATE_ADD('2010-01-01', INTERVAL n.id - 1 SECOND), '%T') AS ts
FROM numbers n) x
LEFT JOIN TABLE y ON y.timestamp = x.ts
GROUP BY x.ts