濮阳杆衣贸易有限公司

主頁 > 知識(shí)庫 > PHP中的mongodb group操作實(shí)例

PHP中的mongodb group操作實(shí)例

熱門標(biāo)簽:福州電銷機(jī)器人源代碼 機(jī)器人外呼系統(tǒng)軟件存在問題 沈陽營銷電銷機(jī)器人招商 高德地圖標(biāo)注商戶位置 南京400電話怎樣辦理 徐州ai電銷機(jī)器人原理 企業(yè)智能外呼系統(tǒng)價(jià)格多少 兗州電話外呼營銷系統(tǒng) 智能電銷機(jī)器人銷售話術(shù)

緊接著上篇來,這篇主要講,mongodb的group功能,做的還是挺強(qiáng)大的,相當(dāng)對(duì)于find(),skip(),distinct()等,用法比較復(fù)雜。

測(cè)試數(shù)據(jù):

復(fù)制代碼 代碼如下:

> db.fruit.find(); 
{ "_id" : 1, "category" : "fruit", "name" : "apple" } 
{ "_id" : 2, "category" : "fruit", "name" : "peach" } 
{ "_id" : 3, "category" : "fruit", "name" : "banana" } 
{ "_id" : 4, "category" : "veggie", "name" : "corn" } 
{ "_id" : 5, "category" : "veggie", "name" : "broccoli" } 

1、根據(jù)category分組

復(fù)制代碼 代碼如下:

> db.fruit.group( 
       { 
         key: { category: 1}, 
         reduce: function(obj, prev) { 
                     prev.items.push(obj.name); 
                 }, 
         initial: { items : [] } 
       } 
    ); 

        { 
                "category" : "fruit", 
                "items" : [ 
                        "apple", 
                        "peach", 
                        "banana" 
                ] 
        }, 
        { 
                "category" : "veggie", 
                "items" : [ 
                        "corn", 
                        "broccoli" 
                ] 
        } 
]

php代碼如下:

復(fù)制代碼 代碼如下:

$keys = array("category" => 1); 
$initial = array("items" => array()); 
$reduce = "function (obj, prev) { prev.items.push(obj.name); }"; 
$g = $collection->group($keys, $initial, $reduce); 
 
print_r($g);   //結(jié)果如下。 
 
Array 

    [retval] => Array 
        ( 
            [0] => Array 
                ( 
                    [category] => fruit 
                    [items] => Array 
                        ( 
                            [0] => apple 
                            [1] => peach 
                            [2] => banana 
                        ) 
 
                ) 
 
            [1] => Array 
                ( 
                    [category] => veggie 
                    [items] => Array 
                        ( 
                            [0] => corn 
                            [1] => broccoli 
                        ) 
 
                ) 
 
        ) 
 
    [count] => 5 
    [keys] => 2 
    [ok] => 1 
)

2、根據(jù)category來分組,并統(tǒng)計(jì)count

復(fù)制代碼 代碼如下:

> db.fruit.group( 
           { 
             key: { category: 1}, 
             cond: { _id: { $gt: 2 } }, 
             reduce: function(obj, prev) { 
                prev.items.push(obj.name); 
                prev.count++; 
             }, 
             initial: { items : [] ,count:0} 
           } 
        ); 

    { 
        "category" : "fruit", 
        "items" : [ 
            "banana" 
        ], 
        "count" : 1 
    }, 
    { 
        "category" : "veggie", 
        "items" : [ 
            "corn", 
            "broccoli" 
        ], 
        "count" : 2 
    } 
]

php代碼如下:

復(fù)制代碼 代碼如下:

$keys = array("category" => 1); 
$initial = array("items" => array(),'count'=>0); 
$reduce = "function (obj, prev) { " . 
              "prev.items.push(obj.name); " . 
              "prev.count++;" . 
          "}"; 
$condition = array('condition' => array("_id" => array( '$gt' => 2))); 
$g = $collection->group($keys, $initial, $reduce, $condition); 
 
print_r($g);   //結(jié)果如下。 
 
Array 

    [retval] => Array 
        ( 
            [0] => Array 
                ( 
                    [category] => fruit 
                    [items] => Array 
                        ( 
                            [0] => banana 
                        ) 
 
                    [count] => 1 
                ) 
 
            [1] => Array 
                ( 
                    [category] => veggie 
                    [items] => Array 
                        ( 
                            [0] => corn 
                            [1] => broccoli 
                        ) 
 
                    [count] => 2 
                ) 
        ) 
 
    [count] => 3 
    [keys] => 2 
    [ok] => 1 

3、利用aggregate group功能,也挺強(qiáng)大

復(fù)制代碼 代碼如下:

> db.fruit.aggregate([ 
                     { $match: { _id: {$gt:0} } }, 
                     { $group: { _id: "$category", count: { $sum: 1 } } }, 
                     { $sort: { count: -1 } } 
                   ]); 
{ "_id" : "fruit", "count" : 3 } 
{ "_id" : "veggie", "count" : 2 } 

php代碼如下:

復(fù)制代碼 代碼如下:

$cond = array( 
    array( 
        '$match' => array('_id' => array('$gt' => 0)), 
    ), 
    array( 
        '$group' => array( 
            '_id' => '$category', 
           'count' => array('$sum' => 1), 
        ), 
    ), 
    array( 
        '$sort' => array("count" => -1), 
    ), 
); 
$result = $collection->aggregate($cond); 
print_r($result);    //結(jié)果如下: 
 
Array 

    [result] => Array 
        ( 
            [0] => Array 
                ( 
                    [_id] => fruit 
                    [count] => 3 
                ) 
 
            [1] => Array 
                ( 
                    [_id] => veggie 
                    [count] => 2 
                ) 
 
        ) 
 
    [ok] => 1 

mongodb 的select 操作有很多,在這里,只是說了一些常用的功能。

您可能感興趣的文章:
  • PHP中安裝使用mongodb數(shù)據(jù)庫
  • PHP中MongoDB數(shù)據(jù)庫的連接、添加、修改、查詢、刪除等操作實(shí)例
  • Thinkphp使用mongodb數(shù)據(jù)庫實(shí)現(xiàn)多條件查詢方法
  • PHP實(shí)現(xiàn)的MongoDB數(shù)據(jù)庫操作類分享
  • PHP對(duì)MongoDB[NoSQL]數(shù)據(jù)庫的操作
  • 解析PHP中常見的mongodb查詢操作
  • php操作MongoDB基礎(chǔ)教程(連接、新增、修改、刪除、查詢)
  • 高效mongodb的php分頁類(不使用skip)
  • PHP7之Mongodb API使用詳解
  • PHP連接MongoDB示例代碼
  • php實(shí)現(xiàn)Mongodb自定義方式生成自增ID的方法
  • PHP數(shù)據(jù)庫操作四:mongodb用法分析

標(biāo)簽:鶴崗 邯鄲 丹東 吉安 本溪 昭通 大理 景德鎮(zhèn)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP中的mongodb group操作實(shí)例》,本文關(guān)鍵詞  PHP,中的,mongodb,group,操作,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PHP中的mongodb group操作實(shí)例》相關(guān)的同類信息!
  • 本頁收集關(guān)于PHP中的mongodb group操作實(shí)例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    高州市| 临汾市| 怀安县| 常宁市| 石家庄市| 德庆县| 菏泽市| 娱乐| 内江市| 永春县| 二连浩特市| 古交市| 伊金霍洛旗| 莱西市| 永康市| 榆林市| 富民县| 涟源市| 普安县| 景泰县| 铜陵市| 民和| 长垣县| 嘉祥县| 六枝特区| 阜平县| 广宗县| 原平市| 贵州省| 尖扎县| 靖西县| 河间市| 南木林县| 平果县| 玉环县| 苏州市| 阿荣旗| 自治县| 霸州市| 阳信县| 加查县|