查询:
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')
返回什么。
我应该有足够多的数据让查询工作。我做错了什么?
当前回答
DATE()是一个MySQL函数,它只提取日期或日期/时间表达式的日期部分
SELECT * FROM table_name WHERE DATE(date_field) BETWEEN '2016-12-01' AND '2016-12-10';
其他回答
第二次约会要在第一次约会之前。您是在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')
你可以手动做,通过比较大于或等于和小于或等于。
select * from table_name where created_at_column >= lower_date and created_at_column <= upper_date;
在我们的示例中,我们需要检索某一天的数据。 我们将从一天的开始到另一天的最后一秒进行比较。
select * from table_name where created_at_column >= '2018-09-01 00:00:00' and created_at_column <= '2018-09-05 23:59:59';
试着换个日期:
2010-09-29 > 2010-01-30?
可能是服务器端或客户端的日期配置有问题。 我发现当主机配置为西班牙语、法语或其他语言时,这是多个数据库上的一个常见问题…这可能会影响dd/mm/yyyy或mm/dd/yyyy格式。
作为对@sabin的回答的延伸,如果有人想只比较日期部分(不比较时间),这是一个提示:
如果要比较的字段来自datetime类型,并且只指定了用于比较的日期,那么这些日期将在内部转换为datetime值。这意味着下面的查询
SELECT * FROM `objects` WHERE (date_time_field BETWEEN '2010-01-30' AND '2010-09-29')
将被转换为
SELECT * FROM `objects` WHERE (date_time_field BETWEEN '2010-01-30 00:00:00' AND '2010-09-29 00:00:00')
在内部。
这将导致结果不包括2010-09-29时间值大于00:00:00的对象!
因此,如果所有日期为2010-09-29的对象也应该包括在内,则要比较的字段必须转换为日期:
SELECT * FROM `objects` WHERE (DATE(date_time_field) BETWEEN '2010-01-30' AND '2010-09-29')