我需要一个查询来选择两个日期之间的数据,以今天的日期作为引用。
数据库有一个“开始”的日期时间字段和一个“结束”的日期时间字段。
$todays_date = date("Y-m-d H:i:s");
$q = "SELECT * FROM news WHERE `end` >= '" . $todays_date . "' AND `start` >= '" . $todays_date . "' ORDER BY id DESC";
问题是查询仍在提取开始日期大于今天的结果。然后我将查询修改为如下所示:
$q = "SELECT * FROM news WHERE `end` >= '" . $todays_date . "' AND `start` >= '" . $todays_date . "' AND `start` <='" . $todays_date . "' ORDER BY id DESC";
这是使用今天日期作为限制器的两个日期时间字段之间选择数据的正确方法吗?
谢谢
最佳答案
您可以使用 MySQL 中的 now timedate 函数和 BETWEEN运营商。
原始 SQL:
SELECT * FROM news
WHERE NOW() BETWEEN start AND end;
注意:请注意提供 MySQL 资源的服务器使用的默认时区,它会影响 NOW() 函数。
关于php - 日期范围查询 MySQL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2007929/