2012-07-22 73 views
1

我使用官方的C#mongodb驅動程序,並且它具有LINQ支持。但我無法嘗試將其轉換爲使用PHP驅動程序。將LINQ查詢轉換爲php mongodb查詢格式

這是LINQ查詢:

.Where(c => DateTime.UtcNow.Subtract(c.DateRequested).TotalDays <= 14).Where(d => ((d.itemid == req.itemid) && (d.MediaType == req.MediaType)) && (d.Status != RequestStatus.Cancelled)) 

我不是100%確定如何,如果我要對這個正確的,但是這是我的企圖迄今爲止可讀格式:

Array 
(
    [$and] => Array 
     (
      [DateRequested] => Array 
       (
        [$gt] => MongoDate Object 
         (
          [sec] => 1341754027 
          [usec] => 0 
         ) 

        [$lte] => MongoDate Object 
         (
          [sec] => 1342963627 
          [usec] => 0 
         ) 

       ) 

      [$and] => Array 
       (
        [$and] => Array 
         (
          [itemid] => 76510 
          [MediaType] => 0 
         ) 

        [Account] => Josh 
       ) 

      [Status] => Array 
       (
        [$ne] => 3 
       ) 

     ) 

) 

這裏是凌亂的形式:

array('$and' => array('DateRequested' => array('$gt' => new MongoDate((time() - 1209600)), '$lte' =>new MongoDate(time())),'$and' => array('$and' => array('itemid' => $itemid,'MediaType' => $source),'Account' => $account),'Status' => array('$ne' => 3))) 

回答

2

不知道如果我從代碼前推斷出您的正確的文檔結構amples以上,但假設在加入測試文檔的mongo外殼類似:

// Insert test data 
db.mycoll.insert({ 
    'DateRequested': new Date(), 
    'itemid': 76510, 
    'MediaType': 0, 
    'Account': 'Josh', 
    'Status': 2 
}); 

PHP中的例子搜索可能看起來像:

<?php 
    $DAYS14 = 14 * 24 * 60 * 60; // Seconds in 14 days 
    $CANCELLED = 3; // Status 

    // Dummy search data 
    $data['itemid'] = 76510; 
    $data['mediatype'] = 0; 
    $data['account'] = 'Josh'; 

    $query = array(
     '$and' => array(
      array('DateRequested' => array('$lt' => new MongoDate(time()))), 
      array('DateRequested' => array('$gte' => new MongoDate(time() - $DAYS14))), 
     ), 
     'itemid' => $data['itemid'], 
     'MediaType' => $data['mediatype'], 
     'Account' => $data['account'], 
     'Status' => array('$ne' => $CANCELLED), 
    ); 

    $document = $collection->findOne($query); 

    // Peek at the result 
    print_r($document); 
?> 

注意查詢元素都隱含使用「和」標準。如果需要重複相同的字段(例如,DateRequested),則需要明確的$and,以便字段密鑰不同。

+1

謝謝。我不知道它使用「和」隱含的那樣。 回答tumbleweed問題的額外點! – Josh 2012-08-28 08:08:23