簡體   English   中英

為什么這個PHP MongoDB查詢沒有返回任何結果,即使有一個?

[英]Why doesn't this PHP MongoDB query return any results even though there is one?

我有一個用戶集合,用戶有一個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.那么這里發生了什么?

MongoDate()接受int time()。 因此,將php date()傳遞給構造函數不起作用。 這是正確的方法:

$daysAgo = new MongoDate(strtotime('-7 days'));

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM