mongodb高级应用
一、 高级查询
- 查询操作符
- 条件操作符:db.collection.find({“field”:{$gt/$lt/$gte/$lte/$eq/$ne:value}});
- 匹配所有:db.collection.find({age:{$all:[6,8]}});//字段的数组中符合全部条件才行。
- 判断字段存在:db.colletion.find({field:{$exists:true}})//还可用于remove等。
- Null值的处理:db.collection.find({field:{“$in”:null,”$exists:true}});
- 取模运算:db.colletion.find({field:{$mod:[10,1]}});
- $ne不等于
- $in包括
- $nin不包括 //$ini和$ne的区别就是ini用于数组检测
- $size匹配数组元素个数
- Count查询记录条数:db.field.find().count();
- Skip显示返回记录的起点:db.students.find().skip(4),跳过前面4条
- Sort排序
- Distinct去重:db.collection.distinct(“field”);查看某字段值的种类。
- Group分组统计
- 查询语法
- 数组内容的查询:通过查询数组的一个属性,可以查出整条文档。
- 内嵌文档的查询:查询文档中field字段中name属性可以find({“field.name”:*});
- 正则表达式匹配查询
- $where查询:命令中不包括where关键字
- 联合查询
- 步骤
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 声明: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});
二、 高级更新
- 数据更新命令
- Update:db.collection.update(criteria,objNew,upsert,multi)
1 Criteria:此处填写查询条件
2 objNew:用$inc的操作
3 upsert:逻辑操作决定在更新操作的时候,没有符合条件的时候是否插入。
4 multi:按照条件查找的多多条的时候,决定多条记录是否同时更新。
- save:如果集合里面有同id的文档,将被覆盖,如果没有,就添加。
- 数据更新操作符
- $inc:{$inc:{field:value}} //对某个字段的数值作品加法
- $set:{$set:{field:value}} //直接修改某个字段的值
- $unset:{$unset:{field:1}} //删除字段
- $push:{$push:{field:value}} //针对数组类型添加值
- $pushAll:{$pushAll:{field:[value1,value2]}} //针对数组类型添加多个值
- $addToSet:{$addToSet:{field:[value1,value2]}} //针对数组类型添加数组
- $pop:{$pop:{field:-1}} //删除数组内的一个值
- $pull:{pull:{field:_value}} //从数组中删除一个等于value的值
- $pullAll:{pullAll:{field:[value1,value2]}} //可以一次删除数组内多个值
- $rename:{$rename:{old_name:new_name}} //字段重命名
- 高级特性
- Capped Collection
1 先预定空间的大小,用完之后就老化溢出。
2 发挥最大的性能,在记录日志不应该创建索引。
3 发挥最大的性能,读比写多的时候不要在上面创建索引。
4 Ps:log speed 是快,data speed 慢。
- GridFS规范
1 海量存储
- 因为BSON的大小限制,大文件会分开。
- Files(包括元数据对象),chunks(二进制块)
2 命令行工具
- Mongofiles put 上传
- Mongofiles get 下载
- MapReduce编程模型
1 Map进行分组
2 Reduce聚合计算
3 Result获取结果
4 Finalize格式化输出
5 Options定制输出
mongodb高级应用的更多相关文章
- MongoDB高级查询用法大全
转载 http://blog.163.com/lgh_2002/blog/static/440175262012052116455/ 详见官方的手册: http://www.mongodb.org/d ...
- DataBase MongoDB高级知识-易使用
MongoDB高级知识-易使用 mongodb是一个面向文档的数据库,而不是关系型数据库.不采用关系模型主要是为了获取更好的扩展性.当然还有其他的一些好处. 与关系型数据库相比,面向文档的数据库不再有 ...
- DataBase MongoDB高级知识-易扩展
MongoDB高级知识-易扩展 应用程序数据集的大小正在以不可思议的速度增长.随着可用宽带的增长和存储器价格的下跌,即使是一个小规模的应用程序,需要存储的数据也可能大的惊人,甚至超出了很多数据库的处理 ...
- DataBase MongoDB高级知识
MongoDB高级知识 一.mongodb适合场景: 1.读写分离:MongoDB服务采用三节点副本集的高可用架构,三个数据节点位于不同的物理服务器上,自动同步数据.Primary和Secondary ...
- mongoDB高级查询$type4array使用解析
今天在使用mongoDB高级查询$type:符号 -- 4代指Array类型发现一个问题. $type符号: $type操作符是基于BSON类型来检索集合中匹配的数据类型,并返回结果. 下面是mong ...
- 【mongoDB高级篇③】综合实战(1): 分析国家地震数据
数据准备 下载国家地震数据 http://data.earthquake.cn/data/ 通过navicat导入到数据库,方便和mysql语句做对比 shard分片集群配置 # step 1 mkd ...
- MongoDB高级知识-易使用
MongoDB高级知识-易使用 mongodb是一个面向文档的数据库,而不是关系型数据库.不采用关系模型主要是为了获取更好的扩展性.当然还有其他的一些好处. 与关系型数据库相比,面向文档的数据库不再有 ...
- MongoDB高级知识-易扩展
MongoDB高级知识-易扩展 应用程序数据集的大小正在以不可思议的速度增长.随着可用宽带的增长和存储器价格的下跌,即使是一个小规模的应用程序,需要存储的数据也可能大的惊人,甚至超出了很多数据库的处理 ...
- MongoDB高级知识
MongoDB高级知识 一.mongodb适合场景: 1.读写分离:MongoDB服务采用三节点副本集的高可用架构,三个数据节点位于不同的物理服务器上,自动同步数据.Primary和Secondary ...
- mongoDB 高级查询语法
http://www.cnblogs.com/ITAres/articles/2084794.html本文参考自官方的手册:http://www.mongodb.org/display/DOCS/Ad ...
随机推荐
- 微信JSAPI支付
最近在微信H5页面内集成微信JSAPI支付,遇到不少问题,现将集成步骤及遇到的问题记录如下: 1.官方下载SDK,下载地址:https://pay.weixin.qq.com/wiki/doc/api ...
- SQLSERVER聚集索引与非聚集索引的再次研究(下)
SQLSERVER聚集索引与非聚集索引的再次研究(下) 上篇主要说了聚集索引和简单介绍了一下非聚集索引,相信大家一定对聚集索引和非聚集索引开始有一点了解了. 这篇文章只是作为参考,里面的观点不一定正确 ...
- CSS系列:CSS常用样式
1. 通用样式 Base.css * { margin:; padding:; } body { width: 1000px; margin: 0 auto; font-size: 12px; fon ...
- 【java】细说 JAVA中 标注 注解(annotation)
Java注解是附加在代码中的一些元信息,用于一些工具在编译.运行时进行解析和使用,起到说明.配置的功能.注解不会也不能影响代码的实际逻辑,仅仅起到辅助性的作用 下面我们来详细说说这个注解,到底是怎么一 ...
- 前端学PHP之PDO基础操作
× 目录 [1]创建PDO [2]使用PDO [3]事务处理 前面的话 PDO(php data object)扩展类库为php访问数据库定义了轻量级的.一致性的接口,它提供了一个数据库访问抽象层,这 ...
- ASP.NET Core 中文文档 第四章 MVC(01)ASP.NET Core MVC 概览
原文:Overview of ASP.NET Core MVC 作者:Steve Smith 翻译:张海龙(jiechen) 校对:高嵩 ASP.NET Core MVC 是使用模型-视图-控制器(M ...
- LinqToDB 源码分析——设计原理
我们知道实现了IQueryable<T>接口和IQueryProvider接口就可以使用Linq To SQL的功能.关于如何去实现的话,上一章也为我们引导了一个方向.LinqToDB框架 ...
- PhpStorm集成xdebug进行断点调试
本文介绍如何使用PhpStorm集成xdebug在本地开发环境进行断点调试的技巧. 我配置的环境是:Windows10 + PhpStorm10.0.1 + PHP5.6. 1. 下载xdebug的扩 ...
- 使用Expression实现数据的任意字段过滤(2)
上一篇<使用Expression实现数据的任意字段过滤(1)>, 我们实现了通过CriteriaCollectionHandler对象来处理集合数据过滤.通过适当的扩展, 应该可以满足一般 ...
- 配置 EPEL yum 源
当我们在linux上, 使用yum 安装包时,报错如下: Loaded plugins: product-id, refresh-packagekit, security, subscription- ...