尝试利用mysql的日期和时间函数。目前,我有一个表格,显示了过去5天 Postman 的路线。这些值作为时间戳存储在我的数据库中。我要这个 Postman 过去三天访问过的所有街道地址。
到目前为止,我可以执行以下查询:
"SELECT RouteEndTime
FROM Mailman GROUP BY RouteEndTime
HAVING DATEDIFF(MAX(RouteEndTime), RouteEndTime) <= 3;"
但我只得到所有15行的routeend值
我正在查看以下资源列表:
https://www.w3schools.com/sql/sql_ref_mysql.asp
在mysql的date函数下,但是没有一个函数可以完成我需要它做的事情。
有没有一个功能,我可以用来获得所有的街道地址,他访问了最近3天(从最近的日期开始在我的数据库)的答案,我要找的基本上是所有的街道地址名称从1月5日,4日和3日。
MailManID | Street Address | RouteStartTime | RouteEndTime
54 | 'Apple St' | '2018-01-05 09:00:00' | '2018-01-05 09:05:00'
54 | 'Bat St' | '2018-01-05 09:30:00' | '2018-01-05 09:35:00'
54 | 'Cat St' | '2018-01-05 09:45:00' | '2018-01-05 09:50:00'
54 | 'Kite St' | '2018-01-04 09:00:00' | '2018-01-04 09:05:00'
54 | 'Lemon St' | '2018-01-04 09:30:00' | '2018-01-04 09:35:00'
54 | 'Muppet St' | '2018-01-04 09:45:00' | '2018-01-04 09:50:00'
54 | 'Luke St' | '2018-01-03 09:00:00' | '2018-01-03 09:05:00'
54 | 'Ben St' | '2018-01-03 09:30:00' | '2018-01-03 09:35:00'
54 | 'Cow St' | '2018-01-03 09:45:00' | '2018-01-03 09:50:00'
54 | 'Hello St' | '2018-01-02 09:00:00' | '2018-01-02 09:05:00'
54 | 'Igloo St' | '2018-01-02 09:30:00' | '2018-01-02 09:35:00'
54 | 'Jump St' | '2018-01-02 09:45:00' | '2018-01-02 09:50:00'
54 | 'Yellow St' | '2018-01-01 09:00:00' | '2018-01-01 09:05:00'
54 | 'Blue St' | '2018-01-01 09:30:00' | '2018-01-01 09:35:00'
54 | 'Red St' | '2018-01-01 09:45:00' | '2018-01-01 09:50:00'
我想回报一些东西,比如:
'Apple St' '2018-01-05 09:00:00' '2018-01-05 09:05:00'
'Bat St' '2018-01-05 09:30:00' '2018-01-05 09:35:00'
'Cat St''2018-01-05 09:45:00' '2018-01-05 09:50:00'
'Kite St''2018-01-04 09:00:00' '2018-01-04 09:05:00'
'Lemon St''2018-01-04 09:30:00' '2018-01-04 09:35:00'
'Muppet St''2018-01-04 09:45:00' '2018-01-04 09:50:00'
'Luke St''2018-01-03 09:00:00' '2018-01-03 09:05:00'
'Ben St''2018-01-03 09:30:00' '2018-01-03 09:35:00'
'Cow St''2018-01-03 09:45:00' '2018-01-03 09:50:00'
1条答案
按热度按时间8i9zcol21#
有关mysql的更好的信息源直接来自他们自己的文档。在这个列表中你会看到
DATEDIFF()
它给出了两个日期之间的天数差。或者类似的东西能满足你的需要。
如果你想要正好三天到第二天,那么使用时间戳就更容易了:
(606024*3是三天内的秒数)
要从数据库中的最后一个时间戳开始测量三天,需要使用max()函数。从这个答案来看,我们看到了
WHERE
不允许MAX()
(子查询除外,但HAVING
将: