为啥这个 PHP MongoDB 查询即使有结果也不返回任何结果?
Posted
技术标签:
【中文标题】为啥这个 PHP MongoDB 查询即使有结果也不返回任何结果?【英文标题】:Why doesn't this PHP MongoDB query return any results even though there is one?为什么这个 PHP MongoDB 查询即使有结果也不返回任何结果? 【发布时间】:2013-07-17 23:10:11 【问题描述】:我有一个用户集合,用户有一个 meta.create_date 字段,它是一个 ISODate,如下所示。我正在尝试计算过去 N 天内创建了多少用户。我在数据库中有以下内容:
"_id" : ObjectId("51e61fa16803fa40130a0581"),
"meta" :
"create_date" : ISODate("2013-07-17T04:37:53.355Z")
我的 php 代码:
$daysAgo = new MongoDate(date('c', strtotime('-7 days')));
$query = array(
'meta.create_date' => array(
'$gte' => $daysAgo,
)
);
$result = $this->db->users->count($query);
我还尝试使用 '$gte' 和 '$lte' 指定一个范围,其中 $lte => 今天。
但是,结果返回为 0。那么这里发生了什么?
【问题讨论】:
【参考方案1】:MongoDate() 需要 int time()。因此,将 php date() 传递给构造函数不起作用。这是正确的方法:
$daysAgo = new MongoDate(strtotime('-7 days'));
【讨论】:
以上是关于为啥这个 PHP MongoDB 查询即使有结果也不返回任何结果?的主要内容,如果未能解决你的问题,请参考以下文章
即使查询相同,PHP 返回的结果也比 phpmyadmin 少
MongoDB,即使它们形成分区,查询字段也会减慢查询速度吗?