如何在MySQL中创建秒列表

时间:2010-07-28 23:13:27

标签: sql mysql aggregate-functions datetime-generation

我有以下查询:

  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出现在结果中?

1 个答案:

答案 0 :(得分:3)

MySQL没有递归功能,因此您只需使用NUMBERS表技巧 -

  1. 创建一个只保存递增数字的表 - 使用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;
    
  2. 使用以下方法填充表格:

    INSERT INTO NUMBERS
      (id)
    VALUES
      (NULL)
    

    ...根据需要提供尽可能多的价值。

  3. 使用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
    
  4. 根据时间部分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