PHP中的mongodb group操作實(shí)例
緊接著上篇來(lái),這篇主要講,mongodb的group功能,做的還是挺強(qiáng)大的,相當(dāng)對(duì)于find(),skip(),distinct()等,用法比較復(fù)雜。
測(cè)試數(shù)據(jù):
> 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分組
> 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代碼如下:
$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來(lái)分組,并統(tǒng)計(jì)count
> 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代碼如下:
$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)大
> 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代碼如下:
$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 操作有很多,在這里,只是說(shuō)了一些常用的功能。
- PHP中安裝使用mongodb數(shù)據(jù)庫(kù)
- PHP中MongoDB數(shù)據(jù)庫(kù)的連接、添加、修改、查詢、刪除等操作實(shí)例
- Thinkphp使用mongodb數(shù)據(jù)庫(kù)實(shí)現(xiàn)多條件查詢方法
- PHP實(shí)現(xiàn)的MongoDB數(shù)據(jù)庫(kù)操作類分享
- PHP對(duì)MongoDB[NoSQL]數(shù)據(jù)庫(kù)的操作
- 解析PHP中常見(jiàn)的mongodb查詢操作
- php操作MongoDB基礎(chǔ)教程(連接、新增、修改、刪除、查詢)
- 高效mongodb的php分頁(yè)類(不使用skip)
- PHP7之Mongodb API使用詳解
- PHP連接MongoDB示例代碼
- php實(shí)現(xiàn)Mongodb自定義方式生成自增ID的方法
- PHP數(shù)據(jù)庫(kù)操作四:mongodb用法分析
相關(guān)文章
詳解MongoDB中用sharding將副本集分配至服務(wù)器集群的方法
副本集是MongoDB的主從復(fù)制中的重要功能,經(jīng)常被用來(lái)作額外的備份,這里我們就來(lái)詳解MongoDB中用sharding將副本集分配至服務(wù)器集群的方法,首先還是來(lái)回顧一下MongoDB中副本集的基本知識(shí):2016-07-07MongoDB設(shè)置登錄賬號(hào)、密碼及權(quán)限的詳細(xì)過(guò)程
這篇文章主要給大家介紹了關(guān)于MongoDB設(shè)置登錄賬號(hào)、密碼及權(quán)限的詳細(xì)過(guò)程,文中通過(guò)代碼以及圖文介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用MongoDB具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-09-09Pycharm連接MongoDB數(shù)據(jù)庫(kù)安裝教程詳解
這篇文章主要介紹了Pycharm連接MongoDB數(shù)據(jù)庫(kù)安裝教程,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-11MongoDB使用自帶的命令行工具進(jìn)行備份和恢復(fù)的教程
這篇文章主要介紹了MongoDB使用自帶的命令行工具進(jìn)行備份和恢復(fù)的教程,我們只需要在命令行界面中用簡(jiǎn)單的命令操作mongorestore和mongodump工具就可以實(shí)現(xiàn),需要的朋友可以參考下2016-06-06vs2019 下用 vb.net編寫窗體程序連接 mongodb4.2的方法
這篇文章主要介紹了vs2019 下用 vb.net編寫窗體程序連接 mongodb4.2,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08mongodb出現(xiàn)id重復(fù)問(wèn)題的簡(jiǎn)單解決辦法
近期在使用mongodb的過(guò)程中遇到一次表中有_id字段重復(fù)的記錄(相同_id的有兩條),著實(shí)嚇了一大跳,這篇文章主要給大家介紹了關(guān)于mongodb出現(xiàn)id重復(fù)問(wèn)題的簡(jiǎn)單解決辦法,需要的朋友可以參考下2021-12-12MongoDB實(shí)現(xiàn)自動(dòng)備份的全過(guò)程記錄
這篇文章主要給大家介紹了關(guān)于MongoDB實(shí)現(xiàn)自動(dòng)備份的全過(guò)程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用MongoDB具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05mongodb中隨機(jī)獲取1條記錄的實(shí)現(xiàn)方法
這篇文章運(yùn)用實(shí)例給大家演示了如何在mongodb中隨機(jī)獲取1條記錄,文中介紹的很詳細(xì),有需要的朋友們可以參考借鑒。下面來(lái)一起看看吧。2016-09-09