查询:
SELECT * FROM `objects`
WHERE (date_field BETWEEN '2010-09-29 10:15:55' AND '2010-01-30 14:15:55')
返回什么。
我应该有足够多的数据让查询工作。我做错了什么?
查询:
SELECT * FROM `objects`
WHERE (date_field BETWEEN '2010-09-29 10:15:55' AND '2010-01-30 14:15:55')
返回什么。
我应该有足够多的数据让查询工作。我做错了什么?
当前回答
显示两个特定日期之间的帖子(例如):
一个场合开始于(04-12),结束于(04-14),而不选择查询中的年份,使其每年在指定的日期上循环,所以我的目标是在开始日期上显示该场合,并在结束日期上自动隐藏它,如下所示:
$stmt = $db->query(
"SELECT * FROM table
WHERE (CAST(CURDATE() AS date)
BETWEEN
CAST(table.date_start AS date)
AND
CAST(table.date_end AS date))
LIMIT 1"
);
现在,事件只在这些指定的日期之间开始和消失,而不是在这之后或之前。
其他回答
date_field是datetime类型吗?此外,你还需要把较早的日期放在前面。
它应该是:
SELECT * FROM `objects`
WHERE (date_field BETWEEN '2010-01-30 14:15:55' AND '2010-09-29 10:15:55')
第二次约会要在第一次约会之前。您是在2010年9月29日至2010年1月30日之间查询的)。试着颠倒一下日期的顺序:
SELECT *
FROM `objects`
WHERE (date_field BETWEEN '2010-01-30 14:15:55' AND '2010-09-29 10:15:55')
DATE()是一个MySQL函数,它只提取日期或日期/时间表达式的日期部分
SELECT * FROM table_name WHERE DATE(date_field) BETWEEN '2016-12-01' AND '2016-12-10';
我刚刚在mariaDB上测试了2个案例,如下:
Case 1: SELECT * FROM table_name WHERE DATE(date_field) BETWEEN '2016-12-01' AND '2016-12-10' // include 2016-12-10
Case 2: SELECT * FROM table_name WHERE (date_field BETWEEN '2016-12-01' AND '2016-12-10') // not include 2016-12-10
可能是服务器端或客户端的日期配置有问题。 我发现当主机配置为西班牙语、法语或其他语言时,这是多个数据库上的一个常见问题…这可能会影响dd/mm/yyyy或mm/dd/yyyy格式。