一、  高级查询

  1. 查询操作符
    1. 条件操作符:db.collection.find({“field”:{$gt/$lt/$gte/$lte/$eq/$ne:value}});
    2. 匹配所有:db.collection.find({age:{$all:[6,8]}});//字段的数组中符合全部条件才行。
    3. 判断字段存在:db.colletion.find({field:{$exists:true}})//还可用于remove等。
    4. Null值的处理:db.collection.find({field:{“$in”:null,”$exists:true}});
    5. 取模运算:db.colletion.find({field:{$mod:[10,1]}});
    6. $ne不等于
    7. $in包括
    8. $nin不包括    //$ini和$ne的区别就是ini用于数组检测
    9. $size匹配数组元素个数
    10. Count查询记录条数:db.field.find().count();
    11. Skip显示返回记录的起点:db.students.find().skip(4),跳过前面4条
    12. Sort排序
    13. Distinct去重:db.collection.distinct(“field”);查看某字段值的种类。
    14. Group分组统计
  2. 查询语法
    1. 数组内容的查询:通过查询数组的一个属性,可以查出整条文档。
    2. 内嵌文档的查询:查询文档中field字段中name属性可以find({“field.name”:*});
    3. 正则表达式匹配查询
    4. $where查询:命令中不包括where关键字
  3. 联合查询
    1. 步骤

1           u=db.user.findOne({author:“ken”});

2           for(var p=db.posting.find({author:u.author});p.hasNext();) {printjson(p.next().title)};

3           上面的解析:先通过名称找出文档,再通过获得的文档中的名称打印title

  1. 游标和存储过程
    1. 游标:结果缓存再读取
    2. 存储过程

1           声明:db.system.js.save({_id: addNumbers value:funtion(x,y){return x+y}});

2           通过id调用:db.eval(‘addNumbers(3,4)’);

3           声明后直接调用:db.eval(function(){return 3+3});

二、  高级更新

  1. 数据更新命令
    1. Update:db.collection.update(criteria,objNew,upsert,multi)

1           Criteria:此处填写查询条件

2           objNew:用$inc的操作

3           upsert:逻辑操作决定在更新操作的时候,没有符合条件的时候是否插入。

4           multi:按照条件查找的多多条的时候,决定多条记录是否同时更新。

  1. save:如果集合里面有同id的文档,将被覆盖,如果没有,就添加。
  2. 数据更新操作符
    1. $inc:{$inc:{field:value}} //对某个字段的数值作品加法
    2. $set:{$set:{field:value}} //直接修改某个字段的值
    3. $unset:{$unset:{field:1}} //删除字段
    4. $push:{$push:{field:value}} //针对数组类型添加值
    5. $pushAll:{$pushAll:{field:[value1,value2]}} //针对数组类型添加多个值
    6. $addToSet:{$addToSet:{field:[value1,value2]}} //针对数组类型添加数组
    7. $pop:{$pop:{field:-1}} //删除数组内的一个值
    8. $pull:{pull:{field:_value}} //从数组中删除一个等于value的值
    9. $pullAll:{pullAll:{field:[value1,value2]}} //可以一次删除数组内多个值
    10. $rename:{$rename:{old_name:new_name}} //字段重命名
  3. 高级特性
    1. Capped Collection

1           先预定空间的大小,用完之后就老化溢出。

2           发挥最大的性能,在记录日志不应该创建索引。

3           发挥最大的性能,读比写多的时候不要在上面创建索引。

4           Ps:log speed 是快,data speed 慢。

  1. GridFS规范

1           海量存储

  1. 因为BSON的大小限制,大文件会分开。
  2. Files(包括元数据对象),chunks(二进制块)

2           命令行工具

  1. Mongofiles put 上传
  2. Mongofiles get 下载
  3. MapReduce编程模型

1           Map进行分组

2           Reduce聚合计算

3           Result获取结果

4           Finalize格式化输出

5           Options定制输出

mongodb高级应用的更多相关文章

  1. MongoDB高级查询用法大全

    转载 http://blog.163.com/lgh_2002/blog/static/440175262012052116455/ 详见官方的手册: http://www.mongodb.org/d ...

  2. DataBase MongoDB高级知识-易使用

    MongoDB高级知识-易使用 mongodb是一个面向文档的数据库,而不是关系型数据库.不采用关系模型主要是为了获取更好的扩展性.当然还有其他的一些好处. 与关系型数据库相比,面向文档的数据库不再有 ...

  3. DataBase MongoDB高级知识-易扩展

    MongoDB高级知识-易扩展 应用程序数据集的大小正在以不可思议的速度增长.随着可用宽带的增长和存储器价格的下跌,即使是一个小规模的应用程序,需要存储的数据也可能大的惊人,甚至超出了很多数据库的处理 ...

  4. DataBase MongoDB高级知识

    MongoDB高级知识 一.mongodb适合场景: 1.读写分离:MongoDB服务采用三节点副本集的高可用架构,三个数据节点位于不同的物理服务器上,自动同步数据.Primary和Secondary ...

  5. mongoDB高级查询$type4array使用解析

    今天在使用mongoDB高级查询$type:符号 -- 4代指Array类型发现一个问题. $type符号: $type操作符是基于BSON类型来检索集合中匹配的数据类型,并返回结果. 下面是mong ...

  6. 【mongoDB高级篇③】综合实战(1): 分析国家地震数据

    数据准备 下载国家地震数据 http://data.earthquake.cn/data/ 通过navicat导入到数据库,方便和mysql语句做对比 shard分片集群配置 # step 1 mkd ...

  7. MongoDB高级知识-易使用

    MongoDB高级知识-易使用 mongodb是一个面向文档的数据库,而不是关系型数据库.不采用关系模型主要是为了获取更好的扩展性.当然还有其他的一些好处. 与关系型数据库相比,面向文档的数据库不再有 ...

  8. MongoDB高级知识-易扩展

    MongoDB高级知识-易扩展 应用程序数据集的大小正在以不可思议的速度增长.随着可用宽带的增长和存储器价格的下跌,即使是一个小规模的应用程序,需要存储的数据也可能大的惊人,甚至超出了很多数据库的处理 ...

  9. MongoDB高级知识

    MongoDB高级知识 一.mongodb适合场景: 1.读写分离:MongoDB服务采用三节点副本集的高可用架构,三个数据节点位于不同的物理服务器上,自动同步数据.Primary和Secondary ...

  10. mongoDB 高级查询语法

    http://www.cnblogs.com/ITAres/articles/2084794.html本文参考自官方的手册:http://www.mongodb.org/display/DOCS/Ad ...

随机推荐

  1. [原创]MYSQL的简单入门

    MYSQL简单入门: 查询库名称:show databases; information_schema mysql test 2:创建库 create database 库名 DEFAULT CHAR ...

  2. PHP_VERSION_ID是如何定义的

    PHP_VERSION_ID是一个整数,表示当前PHP的版本,从php5.2.7版本开始使用的,比如50207表示5.2.7.和PHP版本相关的宏定义在文件 phpsrcdir/main/php_ve ...

  3. Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock'(2)

    center os服务器上搭建discuz论坛初始化程序的时候出现的.我把localhost改成127.0.0.1解决了这个问题.

  4. 数据库日常维护-CheckList_02有关数据库备份检查

    数据库备份是DB日常运维中最基本的也是最重要的工作,很多情况下都是做成作业形式实现自动化周期性的做全备.差异以及日志备份.那么,如果作业出现问题没有完成工作,我们可以设置自动报警如email被动提醒我 ...

  5. 卷积神经网络提取特征并用于SVM

    模式识别课程的一次作业.其目标是对UCI的手写数字数据集进行识别,样本数量大约是1600个.图片大小为16x16.要求必须使用SVM作为二分类的分类器. 本文重点是如何使用卷积神经网络(CNN)来提取 ...

  6. Hive安装部署

    目录 一.        安装Hive. 1 1.       选择CDH版本的... 1 2.       解压文件... 1 二.        配置Hive. 1 1.       配置环境变量 ...

  7. xUnit入门一

    看了下Nhibernate的入门Demo,感觉测试驱动开发会更效率.当然,你可能觉得不是还要额外编程单元测试代码吗?开发怎么会更效率? 一句话解释之,磨刀不误砍柴工. 那就开始入门吧 ~.~ 笔者使用 ...

  8. MVC5+EF6+AutoMapper+Bootstrap打造在线博客(1.1)

    DAL层的三个Model类: 字典表:CFDict 用户表:CFUser 用户爱好表:CFUserHobby(关联cfuser表和cfdict表) CFUser表和CFUserHobby表是一对多关系 ...

  9. GJM :Unity集成Leap Motion

        Demo演示视频

  10. extend

    这段时间在写一个预览图片的插件, 被我老大说了无数次了,不多说啥,说多了都是泪 昨天看着我的代码他说你用了extend,那你知道是什么意思吗 我只知道是扩展的意思,瞬间觉得自己弱爆了 真的 然后今天看 ...