如何对时间戳进行分类?

时间:2016-01-06 14:14:02

标签: mysql datetime timestamp

这是我的表:

+----+-----------------+
| id |    timestamp    |
+----+-----------------+
| 1  | 1452001861      |    -- yesterday
| 2  | 1452088272      |    -- today
| 3  | 1452088283      |    -- today
| 4  | 1451915461      |    -- last week
| 5  | 1452001861      |    -- yesterday
| 6  | 1452088263      |    -- today
| 7  | 1252388263      |    -- out of {today, yesterday, last week}
| 8  | 1452088312      |    -- today
| 9  | 1452001762      |    -- yesterday
| 10 | 1222388263      |    -- out of {today, yesterday, last week}
| 12 | 1451915459      |    -- last week
+----+-----------------+

现在我想选择这样:

+----+-----------------+---------------+
| id |    timestamp    |     range     |
+----+-----------------+---------------+
| 1  | 1452001861      |  yesterday    |
| 2  | 1452088272      |  today        |
| 3  | 1452088283      |  today        |
| 4  | 1451915461      |  last week    |
| 5  | 1452001861      |  yesterday    |
| 6  | 1452088263      |  today        |
| 7  | 1252388263      |  out          |
| 8  | 1452088312      |  today        |
| 9  | 1452001762      |  yesterday    |
| 10 | 1222388263      |  out          |
| 12 | 1451915459      |  last week    |
+----+-----------------+---------------+
//                             ^ this column isn't a real column

嗯,我所能做的只是今天选择:

SELECT
  id,
  date_time
FROM
  viewed
WHERE
DATE_FORMAT(FROM_UNIXTIME(`date_time`), '%Y-%m-%d') >= (DATE_FORMAT(NOW(), '%y-%m-%d') - INTERVAL 1 DAY)

正如我所说,此查询^仅选择今天的时间戳。

我的问题:现在我想知道,如何将查询扩展到{今天​​,昨天 - 上周}?

1 个答案:

答案 0 :(得分:2)

一个不完整的答案让你开始......

SELECT CASE DATE(FROM_UNIXTIME(1452001861)) 
       WHEN CURDATE() - INTERVAL 1 DAY THEN 'yesterday'
       WHEN CURDATE() THEN 'today' END x;