mongoDB 读书笔记(初级命令)
关于mongoDB的相关知识,读书笔记,便于自己查阅用,不定期更新(纯手打) 《mongoDB权威指南》
一、创建更新和删除
1.创建
//批量插入一个集合可以节省时间,只用一次Tcp
//插入时转成bson,并且数据不能大于4mb db.blog.insert({"name":"RedWolf"}) //插入一个文档 文档有一个name键 var temp={"name":"Dog"}
db.blog.insert(temp) //插入一个文档 文档有一个name键
2.删除
db.blog.remove({}) //删除blog中的所有文档,但不会删除集合本身以及索引
db.blog.remove({"age":"18"}) //删除blog中所有age为18的文档
//如果追求速度 删除整个集合,然后再重新创建索引会比较快 相对于删除所有文档
db.blog.drop() //未验证是否真的快很多
3.更新
db.blogs.insert({"name":"joe",age:18,frineds:"tom"})
//以下是更新步骤
var joe=db.blogs.findOne({"name":"joe"}) //此处不可用find() find返回的是游标
joe.relationship={"friends":"kate"}
joe.age=19
db.blogs.update({"name":"joe"},joe);//将修改后的文档进行更新 如果集合中存在多个name为joe的文档,则会尝试更新多条,但是joe中的_id是固定的,所以会造成错误。更新时需注意唯一性
3.1修改器
一般只需修改文档中的部分内容,此时采用修改器比较合适(原子性)
//eg1 记录页面被访问次数的文档,每当被访问的时候加一 $inc 对之后的键加指定值(该值为负可实现减法) 如果键不存在则会添加该建并置为指定值
db.web.insert({"pageName":"cnblogs","times":1})
db.web.update({"pageName":"cnblogs"},{"$inc":{"times":1}})
//eg2 直接修改值 $set 会直接修改 如果修改的键不存在,则会添加该键并置为指定值
db.web.update({"pageName":"cnblogs"},{"$set":{"times":88}}) //eg3 修改内嵌值
db.blog.update({"name":"joe"},{"$set":{"relationship.friends":"Lin"}})
//eg4 删除指定键 $unset会删除指定键 该例中会删除age键
db.blog.update({"name":"joe"},"&unset":{"age":1})
//对数组的操作 $push 会插入到数组的末尾
db.web.insert({"name":"test","bin":[1,2,3,4,6]})
db.web.update({"name":"test"},{"$push":{bin:5}}) db.web.insert({"name":"try","bin":[{"id":1},{"id":2}]})
db.web.update({"name":"try"},{"$push":{"bin":{"id":3}}})
//数组操作 $ne配合 $push
db.web.insert({"name":1,"bin":[1,2,3]});
db.web.insert({"name":2,"bin":[1,2,3,4]}); db.web.update({"name":{"$ne":1}},{"$push":{"bin":4}})//为name为1的文档中的bin添加4
db.web.update({"bin":{"$ne":4}},{"$push":{"bin":4}}) //若bin中没有4,则添加4
//addToSet 如果没有则添加 取代了$ne和$push的组合
db.web.update({"name":1},{"$addToSet":{"bin":20}}) //对于name为1的文档如果bin中没有20则添加
//$addToSet 配合 $each 添加数组中不同的内容
db.web.update({"id":1},{"$addToSet":{"bin":{"$each":[1,2,3,4,5]}}})
//删除数组中的元素 $pop
db.web.update({"id":1},{"$pop":{"bin":1}}) //从数组末尾删除一个
db.web.update({"id":1},{"$pop":{"bin":-1}}) //从数组开头删除一个
//删除数组中的元素 $pull
db.web.update({"id":1},{"$pull":{"bin":1}}) //从数组中删除所有为1的项
//数组的定位操作 $
db.web.update({"bin":3},{"$inc":{"bin.$":3}})
// $upsert 有则更新,没有则根据查询条件和更新内容添加新文档 update的第三个参数为true则为upsert
db.web.update({"id":3},{"$push":{"bin":8}},true)
// $save 存在_id使调用upsert 否则调用insert var x=db.web.findone();
x.id=9
db.web.save(x)
//更新匹配的多个文档
//正常情况下即使匹配多个也只更新匹配到的第一条,update的第四个参数为true则匹配多条 db.web.update("id":{"$ne":100},{"&push":{"bin":100}},false,true) //为所有id不为100的文档的bin添加100
二、查询
//用逗号隔开为多个条件 条件1and条件2
db.web.find({"id":1,"name":"blog"})
//返回指定的键 find函数的第二个参数指定要返回和不需要返回的键 1为需要返回 0为不需要返回
db.web.find({"id":1},{"id":1,"_id:0"})
// $lt $lte $gt $gte 分别对应 < <= > >=
db.web.find({"age":{"$gt":10,"$lt":18}}) //查找age在(10,18)范围的文档
var date=new Date
db.web.find({"datetime":{"$gt":date}})
// $in 某个键值匹配任意一项 $or 任意一个条件达成
db.web.find({"id":{"$in":[1,2,3]}}) //查找id为 1 2或3 的文档
db.web.find({"$or":[{"id":1},{"age":3}]}) //查找id为1或年龄为3的文档
// $mod取余 $not 取反
db.web.find({"id":{"not":{"$mod:[5,1]"}}})
//取id 除5后不余1的id 如2,3,4,5,7
//正则表达式 /××××××××××/
db.web.find({"name":/[0-9]*/}) //查找名称为数字的文档
//查询数组 $all
db.web.find({"bin":{"$all":[1,2,3]}}) //查找bin中包含1,2和3的文档
//要查询键存在,但是值为null的文档 用$exist
db.web.find({"address":{"$in":[null],"$exist":true}})
//查询指定长度的数组 $size
db.web.find({"bin":{"$size":}}) //查询bin有四个元素的文档
//返回指定数量 $slice
db.web.findOne({"id":{"$not":}},{"comments":{"slice":}}) //返回符合条件的前10条
db.web.findOne({"id":{"$not":}},{"comments":{"slice":-}}) //返回符合条件的后10条
db.web.findOne({"id":{"$not":}},{"comments":{"slice":[,]}}) //返回符合条件的6-13的元素
mongoDB 读书笔记(初级命令)的更多相关文章
- MongoDB学习笔记~客户端命令行的使用
回到目录 当我们从MongoDB网站下载安装包之后,它会伴随有一系列的工具,服务器程序mongod是我们耳熟能详的了,客户端mongo和性能检测mongostat我们可能就没有用过了,今天主要是介绍一 ...
- MongoDB整理笔记の指定命令和指定文件
MongoDB shell 不仅仅是一个交互式的shell,它也支持执行指定javascript 文件,也支持执行指定的命令片断.有了这个特性,就可以将MongoDB 与linux shell 完美结 ...
- MongoDB学习笔记—常用命令
这里记录一下MongoDB常用的命令 数据库相关 创建数据库 use DATABASE_NAME 如果数据库不存在,则创建数据库,否则切换到指定数据库. 删除数据库:切换到要删除的数据库下,执行命令即 ...
- 《JavaScript设计模式与开发实践》读书笔记之命令模式
1.命令模式 1.1 传统的命令模式 命令模式的应用场景:请求的发送者和请求接收者消除彼此耦合关系 以页面点击按钮为例 点击按钮后,借助命令对象,解开按钮和负责具体行为对象之间的耦合 <body ...
- [读书笔记]Linux命令行与shell编程读书笔记04 安装软件,编辑器注意事项
1. debian以及redhat两种主流的linux发行版用的包管理工具 debian的包管理工具是 dpkg 再现安装的是 apt apt的工具主要有 apt-get apt-cache apti ...
- [读书笔记]Linux命令行与shell编程读书笔记03 文件系统等
1. 文件系统的种类 ext ext2 ext3 ext4 JFS XFS 其中ext3 开始支持journal日志模式 与raid卡类似 有 数据模式 排序模式 以及回写模式 数据模式最安全 回写 ...
- [读书笔记]Linux命令行与shell编程读书笔记02 环境变量以及其他
1. Linux的环境变量. 全局环境变量的查看 printenv 一个结果示例 XDG_SESSION_ID=354TERM=xtermSHELL=/bin/bashSSH_CLIENT=10.24 ...
- [读书笔记]Linux命令行与shell编程读书笔记01
1. Linux的组成部分 1)linux内核(kernel) 2)GNU工具链 3)GUI/CLI工作几面(shell) 4)应用程序(app) 2Linux内核的主要工作: 1) 管理内存 2)管 ...
- MongoDB学习笔记系列
回到占占推荐博客索引 该来的总会来的,Ef,Redis,MVC甚至Sqlserver都有了自己的系列,MongoDB没有理由不去整理一下,这个系列都是平时在项目开发时总结出来的,希望可以为各位一些帮助 ...
随机推荐
- 转:mysql中int、bigint、smallint 和 tinyint的区别与长度的含义
bigint 从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据(所有数字).存储大小为 8 个字节. P.S. b ...
- ArcEngine 不能再打开其他表了
在IFeatureClass.Search()是弹出这个问题,根据网上的资料,采用 System.Runtime.InteropServices.Marshal.ReleaseComObject()或 ...
- ArcEngine 获取像元值
栅格数据获取像元值, 使用ISurface.GetElevation(IPoint pnt),功能是实现了,获取的 不是像元值,是插值结果.而由于栅格数据是离散的值,每个栅格值代表了特殊的含义,插值之 ...
- 记save函数
在写商品修改的代码的时候,我使用到了create()函数,也使用到了save函数.但是我从表单接受过来的数据,在添加语句的时候都没成功.代码如下 function upd($goods_id){ $g ...
- 将MyApp.exe和Autorun.lnk添加到NK里,在project.bib文件内加入
1. 将应用程序和应用程序快捷方式添加到映像里,再将快捷方式添加到StartUp目录下,这样当系统运行后应用程序就能自动运行:2. 直接替换Wince的SHELL,即修改注册表: [HKEY_LOCA ...
- 移动Web应用开发入门指南——视觉篇
视觉篇 智能移动设备由于发展历史短,但更新速度快,从而导致移动设备的物理属性差异巨大,其中一部分物理属性影响视觉,另一部分影响到交互.兼容或性能.对人类来说,至少有80%以上的外界信息通过视觉获得,视 ...
- Linux文件管理命令
cd /home 进入 '/ home' 目录' cd .. 返回上一级目录 cd ../.. 返回上两级目录 cd 进入个人的主目录 cd ~user1 进入个人的主目录 cd - 返回上次所在的目 ...
- dom4j最常用最简单的方法
要使用dom4j读写XML文档,需要先下载dom4j包,dom4j官方网站在 http://www.dom4j.org/目前最新dom4j包下载地址:http://nchc.dl.sourceforg ...
- C# vba 操作 Word
添加引用 Microsoft Word *.0 Object Library Microsoft Graph *.0 Object Library 变量说明 Object oMissing = Sy ...
- thinkphp的save方法失败
如果用下面的方式更新数据时, $data['link_phone'] = I('post.link_phone'); $flag1 = $order->save ($data); $data一定 ...