紧接着上篇来,这篇主要讲,mongodb的group功能,做的还是挺强大的,相当对于find(),skip(),distinct()等,用法比较复杂。 测试数据 db.fruit.find();{ "_id" : 1, "category" : "fruit", "name" : "apple" }{ "_id" : 2, "category" : "fruit", "name" :
紧接着上篇来,这篇主要讲,mongodb的group功能,做的还是挺强大的,相当对于find(),skip(),distinct()等,用法比较复杂。
测试数据
> 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,根据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);?? //结果如下。 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,根据category来分组,并统计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);?? //结果如下。 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功能,也挺强大
> 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); //结果如下: Array ( ??? [result] => Array ??????? ( ??????????? [0] => Array ??????????????? ( ??????????????????? [_id] => fruit ??????????????????? [count] => 3 ??????????????? ) ??????????? [1] => Array ??????????????? ( ??????????????????? [_id] => veggie ??????????????????? [count] => 2 ??????????????? ) ??????? ) ??? [ok] => 1 )
mongodb 的select 操作有很多,在这里,只是说了一些常用的功能。
原文地址:mongodb group php 操作, 感谢原作者分享。

mysqlviewshavelimitations:1)他们不使用Supportallsqloperations,限制DatamanipulationThroughViewSwithJoinSorsubqueries.2)他们canimpactperformance,尤其是withcomplexcomplexclexeriesorlargedatasets.3)

porthusermanagementInmysqliscialforenhancingsEcurityAndsingsmenting效率databaseoperation.1)usecReateusertoAddusers,指定connectionsourcewith@'localhost'or@'%'。

mysqldoes notimposeahardlimitontriggers,butacticalfactorsdeterminetheireffactective:1)serverConfiguration impactactStriggerGermanagement; 2)复杂的TriggerSincreaseSySystemsystem load; 3)largertablesslowtriggerperfermance; 4)highConconcConcrencerCancancancancanceTigrignecentign; 5); 5)

Yes,it'ssafetostoreBLOBdatainMySQL,butconsiderthesefactors:1)StorageSpace:BLOBscanconsumesignificantspace,potentiallyincreasingcostsandslowingperformance.2)Performance:LargerrowsizesduetoBLOBsmayslowdownqueries.3)BackupandRecovery:Theseprocessescanbe

通过PHP网页界面添加MySQL用户可以使用MySQLi扩展。步骤如下:1.连接MySQL数据库,使用MySQLi扩展。2.创建用户,使用CREATEUSER语句,并使用PASSWORD()函数加密密码。3.防止SQL注入,使用mysqli_real_escape_string()函数处理用户输入。4.为新用户分配权限,使用GRANT语句。

mysql'sblobissuitableForStoringBinaryDataWithInareLationalDatabase,而alenosqloptionslikemongodb,redis和calablesolutionsoluntionsoluntionsoluntionsolundortionsolunsolunsstructureddata.blobobobsimplobissimplobisslowderperformandperformanceperformancewithlararengelitiate;

toaddauserinmysql,使用:createUser'username'@'host'Indessify'password'; there'showtodoitsecurely:1)choosethehostcarecarefullytocon trolaccess.2)setResourcelimitswithoptionslikemax_queries_per_hour.3)usestrong,iniquepasswords.4)Enforcessl/tlsconnectionswith

toAvoidCommonMistakeswithStringDatatatPesInMysQl,CloseStringTypenuances,chosethirtightType,andManageEngencodingAndCollationsEttingsefectery.1)usecharforfixed lengengters lengengtings,varchar forbariaible lengength,varchariable length,andtext/blobforlabforlargerdata.2 seterters seterters seterters seterters


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器

SublimeText3汉化版
中文版,非常好用

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)