数据的保存

  1. include_once 'mDB.class.php';
  2. $m=new mDB();
  3. $m->setDB('mydb');
  4. // $m->save('stu',['dept'=>'财务','name'=>'张三','age'=>73]);
  5. // $m->save('stu',['dept'=>'计算机','name'=>'张四','age'=>53]);
  6. // $m->save('stu',['dept'=>'计算机','name'=>'张五','age'=>23]);
  7. // $m->save('stu',['dept'=>'财务','name'=>'张六','age'=>93]);
  8. // $m->save('stu',['dept'=>'计算机','name'=>'张七','age'=>83]);
  9. // $m->save('stu',['dept'=>'法学','name'=>'张八','age'=>53]);
查询出所有的专业
  1. $db=$m->getMongoClient();
  2. $d=$db->mydb;
  3. $c=$d->stu;
  4. // echo $c->find(['dept'=>'计算机'])->count();//返回计算机专业有几人
  5. $currsor=$c->find([],['_id'=>0,'dept'=>1]);
  6. foreach ($currsor as $v){
  7. echo $v['dept'].'<br>';
  8. }

消除重复取出各个专业的名字distinct
  1. $db=$m->getMongoClient();
  2. $d=$db->mydb;
  3. $c=$d->stu;
  4. $depts=$c->distinct('dept');
  5. foreach ($depts as $v){
  6. echo $v.'<br>';
  7. }

统计各个专业的人数
  1. include_once 'mDB.class.php';
  2. $m=new mDB();
  3. $m->setDB('mydb');
  4. $db=$m->getMongoClient();
  5. $d=$db->mydb;
  6. $c=$d->stu;
  7. $depts=$c->distinct('dept');
  8. foreach ($depts as $v){
  9. echo $v;
  10. echo '专业人数'.$c->find(['dept'=>$v])->count();
  11. echo '<hr>';
  12. }

分组查询的所有代码
  1. <?php
  2. header('content-type:text/html;charset=UTF-8');
  3. //无密码直接登录mongodb
  4. $m = new MongoClient('mongodb://localhost:27017');
  5. $db = $m->selectDB('aaa');
  6. $c1 = $db->student;
  7. //$c1->insert(array("category" => "计算机", "name" => "张在",'age'=>33));
  8. //$c1->insert(array("category" => "计算机", "name" => "李四",'age'=>25));
  9. //$c1->insert(array("category" => "英语", "name" => "赵六",'age'=>30));
  10. //$c1->insert(array("category" => "英语", "name" => "赵七",'age'=>40));
  11. //$c1->insert(array("category" => "会计", "name" => "李勇",'age'=>10));
  12. //$keys = array("category" => 1);
  13. //$initial = array("items" => array());
  14. //$reduce = "function (obj, prev) { prev.items.push(obj);}";
  15. //$reduce = "function (obj, prev) { prev.items.push(obj.name);}";
  16. //$reduce = "function (obj, prev) { prev.items.push(obj.name+obj.age);}";
  17. //$g = $c1->group($keys, $initial, $reduce);
  18. //echo json_encode($g['retval']);
  19. //echo '<pre>';
  20. //print_r($g);
  21. //统计各专业人数
  22. // $keys = array("category" => 1); //指定分类属性
  23. // $initial = array("count" => 0);
  24. // $reduce = "function (obj, prev) { prev.count++; }";
  25. // $condition = array('condition' => array());//条件
  26. // $g = $c1->group($keys, $initial, $reduce, $condition);
  27. // var_dump($g);
  28. //统计年龄大于等于25岁的总人数
  29. // $keys=[];
  30. // $initial = ['c'=>0];
  31. // $reduce = 'function(obj,prev){prev.c++;}';
  32. // $where = ['condition'=>['age'=>['$gte'=>25]]];
  33. // $g = $c1->group($keys,$initial,$reduce,$where);
  34. // var_dump($g);
  35. //求出各专业学生年龄之和 select category,sum(age) from student group by category;
  36. // $keys=['category'=>1];
  37. // $initial = ['sum'=>0];
  38. // $reduce = "function(obj,prev){prev['sum'] += obj.age; }";
  39. // $g = $c1->group($keys,$initial,$reduce);
  40. // var_dump($g);
  41. //根据专业,来统计各专业的最大年龄
  42. // $keys=['category'=>1];
  43. // $initial = ['max'=>0];
  44. // $reduce = "function(obj,prev){if(obj.age>prev['max']){prev['max']=obj.age;} }";
  45. // $g = $c1->group($keys,$initial,$reduce);
  46. // var_dump($g);
  47. //根据专业分组,求出每个专业的人数,平均年龄,年龄总各
  48. $keys=['category'=>1];
  49. $initial = ['sum'=>0,'count'=>0,'avg'=>0];
  50. $reduce = "function(obj,prev){prev['sum'] += obj.age;prev['count']++;prev['avg']=prev['sum']/prev['count']}";
  51. $g = $c1->group($keys,$initial,$reduce);
  52. var_dump($g);
  53. $m->close();
查询出所有的信息
  1. include_once 'mDB.class.php';
  2. $m=new mDB();
  3. $m->setDB('mydb');
  4. $db=$m->getMongoClient();
  5. $d=$db->mydb;
  6. $c=$d->stu;
  7. $keys = ["dept" => 1]; //指定分类属性
  8. $initial = array("count" => 0);
  9. $reduce = "function (obj, prev) { prev.count++; }";
  10. $condition = array('condition' => array());//条件
  11. $g = $c->group($keys, $initial, $reduce, $condition);
  12. echo '<pre>';
  13. var_dump($g);

统计出所有的信息
$reduce = "function (obj, prev) { prev.count++; }";此句为程序里面的死命令
  1. <?php
  2. include_once 'mDB.class.php';
  3. $m=new mDB();
  4. $m->setDB('mydb');
  5. $db=$m->getMongoClient();
  6. $d=$db->mydb;
  7. $c=$d->stu;
  8. $keys = ["dept" => 1]; //指定分类属性
  9. $initial = array("count" => 0);
  10. $reduce = "function (obj, prev) { prev.count++; }";
  11. $condition = array('condition' => array());//条件
  12. $g = $c->group($keys, $initial, $reduce, $condition);
  13. echo '<pre>';
  14. var_dump($g);
  15. echo '总人数'.$g['count'];
  16. echo '<br>总专业'.$g['keys'].'个专业<br>';
  17. foreach ($g['retval'] as $v){
  18. echo $v['dept'].'人数'.$v['count'].'人';
  19. }

"function(obj,prev){
    prev['sum'] += obj.age;
    prev['count']++;
    prev['avg']=prev['sum']/prev['count'];
   if(obj.age>prev['max']){prev['max']=obj.age;}
    if(obj.age<prev['min']){prev['min']=obj.age;}
}";  
求出平均分,最高分,最低分,各专业的总分
  1. <?php
  2. include_once 'mDB.class.php';
  3. $m=new mDB();
  4. $m->setDB('mydb');
  5. $db=$m->getMongoClient();
  6. $d=$db->mydb;
  7. $c=$d->stu;
  8. //根据专业分组,求出每个专业的人数,平均年龄,年龄总各
  9. $keys=['dept'=>1];
  10. $initial = ['sum'=>0,'count'=>0,'avg'=>0,'max'=>0,'min'=>100];
  11. $reduce ="function(obj,prev){
  12. prev['sum'] += obj.age;
  13. prev['count']++;
  14. prev['avg']=prev['sum']/prev['count'];
  15. if(obj.age>prev['max']){prev['max']=obj.age;}
  16. if(obj.age<prev['min']){prev['min']=obj.age;}
  17. }";
  18. $g = $c->group($keys,$initial,$reduce);
  19. echo '<pre>';
  20. var_dump($g);
  21. foreach ($g['retval'] as $v){
  22. echo $v['dept'].'平均分'.$v['avg'].'最高分'.$v['max'].'最低分'.$v['min'].'各专业总分为'.$v['sum'].'<br>';
  23. }

mongodb 分组查询的更多相关文章

  1. MongoDB分组查询,聚合查询,以及复杂查询

    准备数据 from pymongo import MongoClient import datetime client=MongoClient('mongodb://localhost:27017') ...

  2. Mongodb 分组查询例子

    db.tblCard.aggregate([     {         $match: {             "sNo": {                 " ...

  3. MongoDB之 分组查询

    分组查询 可视化工具 https://robomongo.org pymongo from pymongo import MongoClient # 方式一: c = MongoClient(host ...

  4. Mongodb for C# 分组查询

    #region 排序获取集合 static List<BsonDocument> GetPagerWithGroup(string connectionString, string dat ...

  5. mongodb使用mongoose分组查询

    一个分组查询的例子: model.aggregate([{$match: ops}, {$unwind: '$details'}, {$sort: {create_at: -1}}, { $group ...

  6. MongoDB聚合查询

    1.count:查询记录条数 db.user.count() 它也跟find一样可以有条件的 db.user.count({}) 2.distinct:用来找出给定键的所有不同的值 db.user.d ...

  7. Mongodb高级查询【二】

    上一篇文章,写了mongodb常规操作,继续写入,本章主要讲高级查询,文本,聚集,大数据查询. Mongodb的查询语法是很多的,是NOSQL队伍中比较丰富的一个.当然有很多查询跟关系型查询无法相比. ...

  8. 使用c#对MongoDB进行查询(1)

    1.BsonDocument对象 在MongoDB.Bson命名空间下存在一个BsonDocument类,它是MongoDB的文档对象,代表着MongoDB中不规则数据一条条实体模型.可以使用Bson ...

  9. BBS--功能4:个人站点页面设计(ORM跨表与分组查询)

    查询: 日期归档查询 1 date_format ============date,time,datetime=========== create table t_mul_new(d date,t t ...

随机推荐

  1. mybatis 与 缓存

    首先从配置文件说起,有个cacheEnabled的配置项,当设置为true时(默认就是true),Session就会用一个CachingExecutor来包装我们的Executor实例: public ...

  2. webpack的几个使用方法

    1.gulp.task -> webpack -> webpack.config.js -> bundle.js -> html 2.cmd -> npm run -&g ...

  3. JavaScript使用XMLHttpRequest 發送GET/Post 請求

    <!DOCTYPE HTML> <html> <head> <title>Demo</title> <script type=&quo ...

  4. [2016.08.09]文本替换专家 v5.2

    软件名称:文本替换专家最新版本:v5.2软件授权:共享软件发布日期:2016.01.18文件大小:650KB操作系统:XP/2003/Win7/Win2008开发人员:胡洪祥版权所有:胡洪祥

  5. mybatis实战教程(mybatis in action)之三:实现数据的增删改查

    前面已经讲到用接口的方式编程.这种方式,要注意的一个地方就是.在User.xml  的配置文件中,mapper namespace="com.yihaomen.mybatis.inter.I ...

  6. vscode配置

    默认的挺难看的 颜色主题换成 Monokai Dimmed 用户设置 // 将设置放入此文件中以覆盖默认设置 { "editor.fontFamily": "Monaco ...

  7. windows和linux实现文件共享

    linux和windows实现共享,需要安装samba服务器 安装步骤: 1.查看是否已经安装samba rpm -q samba 2.如果已经安装,如果你想再次安装,可以卸载 rpm -e samb ...

  8. delphi中webbrowser的用法

    WebBrowser1.GoHome; //到浏览器默认主页 WebBrowser1.Refresh; //刷新 WebBrowser1.GoBack; //后退 WebBrowser1.GoForw ...

  9. Logstash5.0.X离线安装插件报错,仍然提示无法联网

    本人最初将此解决方案发布在 ELK中文社区 http://elasticsearch.cn/question/1046 由于生产环境无法连接互联网,所有再一台联网机器上将所有插件做了 pack 拖到生 ...

  10. web app开发之rem

    CSS3新增了一个相对单位rem,官方的解释为“font size of the root element”,相对于根元素(html)的font size. rem,em,px单位的区别: rem单位 ...