mongodb学习之:文档操作

在上一章中有讲到文档的插入操作是用insert的方法。如果该集合不在该数据库中,mongodb会自动创建该集合并插入文档

用find的方法可以查找所有的集合数据

> db.maple.find()

{ "_id" : ObjectId("5a35d6278ef76f6d57aae92c"), "name" : "zhf"

也可以将数据定义为一个变量:

document=({“name”:”zhf”})

db.maple.insert(document)

文档更新:

MongoDB 使用 update() 和 save() 方法来更新集合中的文档

参数说明:

query : update的查询条件,类似sql update查询内where后面的。

update : update的对象和一些更新的操作符(如$,$inc...)等,也可以理解为sql update查询内set后面的

upsert : 可选,这个参数的意思是,如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。

multi : 可选,mongodb 默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。

writeConcern :可选,抛出异常的级别。

db.maple.update({"name":"zhf"},{"$set":{"name":"zhanghongfeng"}})

还可以采用运算符的方式来进行判断

> db.maple.update({"age":{"$eq":35}},{"$set":{"city":"chengdu"}})

#找到年龄等于35的文档并将城市设置为chengdu

> db.maple.update({"city":"chengdu"},{"$inc":{"age":1}})

#找到城市为chengdu的文档并将age加1

> db.maple.update({"city":"chengdu"},{"$inc":{"age":-1}})

#找到城市为chengdu的文档并将age减1

#unset:删除某个字段

> db.maple.update({"age":35},{$unset:{"programming":1}})

WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

> db.maple.find()

{ "_id" : ObjectId("5a35d6278ef76f6d57aae92c"), "name" : "zhanghongfeng_maple" }

{ "_id" : ObjectId("5a35d7ce8ef76f6d57aae92d"), "age" : 35, "city" : "chongqing" }

{ "_id" : ObjectId("5a35d8548ef76f6d57aae92e"), "favorite" : "basketball" }

{ "_id" : ObjectId("5a3611de366b42e0050debd8"), "coding" : [ "C", "python", "Go", "Java" ] }

$push操作:把value追加到field里面去,field一定要是数组类型才行,如果field不存在,会新增一个数组类型加进去

> db.maple.update({"age":35},{$push:{"programming":"javascript"}})

> db.maple.find()

{ "_id" : ObjectId("5a35d6278ef76f6d57aae92c"), "name" : "zhanghongfeng_maple" }

{ "_id" : ObjectId("5a35d7ce8ef76f6d57aae92d"), "age" : 35, "city" : "chongqing", "programming" : [ "javascript" ] }

{ "_id" : ObjectId("5a35d8548ef76f6d57aae92e"), "favorite" : "basketball" }

{ "_id" : ObjectId("5a3611de366b42e0050debd8"), "coding" : [ "C", "python", "Go", "Java" ] }

#当数组不存在的时候会新增一个数组

> db.maple.update({"age":35},{$push:{"programming":"mysql"}})

WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

> db.maple.find()

{ "_id" : ObjectId("5a35d6278ef76f6d57aae92c"), "name" : "zhanghongfeng_maple" }

{ "_id" : ObjectId("5a35d7ce8ef76f6d57aae92d"), "age" : 35, "city" : "chongqing", "programming" : [ "javascript", "mysql" ] }

{ "_id" : ObjectId("5a35d8548ef76f6d57aae92e"), "favorite" : "basketball" }

{ "_id" : ObjectId("5a3611de366b42e0050debd8"), "coding" : [ "C", "python", "Go", "Java" ] }

#已存在的情况下则会继续往数组里面添加数据

> db.maple.update({"age":35},{$pushAll:{"programming":["object-c","HTML"]}})

WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

> db.maple.find()

{ "_id" : ObjectId("5a35d6278ef76f6d57aae92c"), "name" : "zhanghongfeng_maple" }

{ "_id" : ObjectId("5a35d7ce8ef76f6d57aae92d"), "age" : 35, "city" : "chongqing", "programming" : [ "javascript", "mysql", [ "mongodb", "linux" ], "object-c", "HTML" ] }

{ "_id" : ObjectId("5a35d8548ef76f6d57aae92e"), "favorite" : "basketball" }

{ "_id" : ObjectId("5a3611de366b42e0050debd8"), "coding" : [ "C", "python", "Go", "Java" ] }

#添加多个数据到数组中采用pushAll的方式

#addToSet

只有在数组中不存在的时候才添加:

> db.maple.update({"age":35},{$addToSet:{"programming":"mysql"}})

WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 0 })

#pop

删除第一个和最后一个元素

> db.maple.update({"age":35},{$pop:{"programming":1}})

WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

> db.maple.update({"age":35},{$pop:{"programming":-1}})

WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

#pull:删除特定的元素

> db.maple.update({"age":35},{$pull:{"programming":"object-c"}})

WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

文档查找:

我们用关系数据库中的对比来看下:

db.maple.find() 相当于select * from maple
db.maple.find({"age":27}) 相当于select * from maple where age=‘27‘
db.maple.find({"age":27,"name":"xing"}) 相当于select * from maple where age=‘27‘ and name="xing"
db.maple.find({},{"name":1}) select name from maple,如果name:0则是不显示name字段
db.maple.find().limit(1) 相当于select * from maple limit 1

db.maple.find().sort({_id:-1}).limit(1)相当于select * from maple order by _id desc limit 1

db.maple.find({"age":{"$in",[12,34,100]}})  相当于select * from maple where age in (12,3,100)
db.maple.find({"age ":{"$nin",[12,3,100]}})  相当于select * from maple where _id not in (12,3,100)
db.maple.find({"$or":[{"age":16},{"name":"xing"}]}) 相当于select * from blog where age = 16 or name = ‘xing‘
db.maple.find({"id_num":{"$mod":[5,1]}}) 取的是id_num mod 5 = 1 的字段,如id_num=1,6,11,16
db.maple.find({"id_num":{"$not":{"$mod":[5,1]}}}) 取的是id_num mod 5 != 1 的字段,如除了id_num=1,6,11,16等所有字段,多于正则一起用

$exists判断字段是否存在

db.blog.find({ “name” : { $exists : true }}); // 如果存在元素name,就返回
db.blog.find({ “name” : { $exists : false }}); // 如果不存在元素name,就返回

#查询数组:

db.blog.find({"coding":{"$size":4}})  coding数组长度为3的符合结果

db.blog.find({"coding":{"$all":["C", "python", "Go", "Java" ]}})   fruit中必需有数组中的每一个才符合结果

时间: 2024-11-09 01:48:59

mongodb学习之:文档操作的相关文章

ExtJs4学习(二):Dom文档操作

现在主流的JS框架要数ExtJs和JQuery应用的比较广泛.JQuery属于轻量级的,一般做网站应用比较常见,可见块头小的优势.ExtJs比较庞大,它除了对基本的JS语法和HTML DOM操作方式的封装之外,还提供了一套强大的UI库.在企业级B/S解决方案应用上独占优势.就单说它在原生JS的封装,DOM操作方式封装方面也足以藐视JQuery.下面我就通过对比API,体现两种框架的异曲同工之处.我们已JQuery API为主线,来看看ExtJs是否有替代的方案. 注意一点:ExtJs4.0相对上

电商项目实战(架构七)——Mongodb实现文档操作

一.前言 对于频繁读写的功能,例如商品的浏览记录,Mongodb中的添加.删除.查询可以很好的解决.Mongodb是为快速开发互联网Web应用而构建的数据库系统,其数据模型和持久化策略就是为了构建高 读/写 吞吐量和高自动灾备伸缩性的系统. 二.Mongodb的安装和使用(windows系统下) 1.下载Mongodb安装包,下载地址:https://fastdl.mongodb.org/win32/mongodb-win32-x86_64-2008plus-ssl-3.2.21-signed.

dom文档操作-学习

今天出门,发现家猫,吐在我的鞋子上.猫猫觉得我不紧要当铲屎官还要当擦鞋官啊. 上次用css和html做了个防站酷的静态首页后,觉得现在改学学文档操作了.上w3c看了下文档操作. 大致理解操作步骤, 1.通过浏览器window对象,获取里面的熟悉document,这个表示当前文档对象, 2.获取document后,document里面有三个核心方法:getElementByClass,getElementByName,getElementByTag,姑且称为getElement三兄弟吧. 3.然后

MongoDB数据库文档操作

前面的话 本文将详细介绍MongoDB数据库关于文档的增删改查 插入文档 要将数据插入到 MongoDB 集合中,需要使用 MongoDB 的 insert()或save()方法,还有insertOne()或insertMany()方法 [insert()] insert()命令的基本语法如下 db.COLLECTION_NAME.insert(document) 在插入的文档中,如果不指定_id参数,那么 MongoDB 会为此文档分配一个唯一的ObjectId._id为集合中的每个文档唯一的

Mongoose学习参考文档——基础篇

Mongoose学习参考文档 前言:本学习参考文档仅供参考,如有问题,师请雅正 一.快速通道 1.1 名词解释 Schema : 一种以文件形式存储的数据库模型骨架,不具备数据库的操作能力 Model : 由Schema发布生成的模型,具有抽象属性和行为的数据库操作对 Entity : 由Model创建的实体,他的操作也会影响数据库 注意: 1.本学习文档采用严格命名方式来区别不同对象,例如: var PersonSchema; //Person的文本属性 var PersonModel; //

MongoDB实战-面向文档的数据(找到最合适的数据建模方式)

前一段时间一直研究通过Ruby操作MongoDB数据库,在学习的过程中也分享了自己学习成长的过程,撰写了包含两篇入门操作文章和十二篇进阶文章.本篇文章开始,我们将进入MongoDB的实战操作流程,MongoDB这一非关系型数据库-是一个文档型数据库,存储的是面向文档的数据. 如何在MongoDB数据库中使用schema 设计数据库schema是在已知数据库系统特性.数据本质以及应用程序需求的情况下为数据集选择最佳表述的过程.传统的关系型数据库RDBMS中鼓励使用正规化的数据模型,从而确保数据的可

mongodb 学习笔记 02 -- CURD操作

mongodb 学习笔记 02 – CURD操作 CURD代表创建(Create).更新(Update).读取(Read)和删除(Delete)操作 创建库 直接 use 库名 然后创建collection 就可以创建库 创建collecion db.createCollection("collectionName") 隐式创建collection db.collectionName.insert({xxxxxx}) 删除collection db.collectionName.dro

SpringMVC MongoDB之“基本文档查询(Query、BasicQuery)”

一.简介 spring Data  MongoDB提供了org.springframework.data.mongodb.core.MongoTemplate对MongoDB的CRUD的操作,上一篇我们介绍了对MongoDB的新增和删除, 今天我们要介绍Java代码实现对MongoDB实现查询操作. 我们回顾一下,我们在之前介绍了MongoDB的基本文档查询,MongoDB的查询语法: db.orders.find({{<field1>:<value1>,<field2>

06-jQuery的文档操作***

之前js中咱们学习了js的DOM操作,也就是所谓的增删改查DOM操作.通过js的DOM的操作,大家也能发现,大量的繁琐代码实现我们想要的效果.那么jQuery的文档操作的API提供了便利的方法供我们操作我们的文档. 看一个之前我们js操作DOM的例子: var oUl = document.getElementsByTagName('ul')[0]; var oLi = document.createElement('li'); oLi.innerHTML = '赵云'; oUl.appendC

jQuery的文档操作(重点)/简单接触ajax(和风天气)

一.jQuery的文档操作****** 之前js中学习了js的DOM操作,也就是所谓的增删改查DOM操作.通过js的DOM的操作,大家也能发现,大量的繁琐代码实现我们想要的效果.那么jQuery的文档操作的API提供了便利的方法供我们操作我们的文档. 看一个我们JS操作DOM的例子: var oUl = document.getElementsByTagName('ul')[0]; var oLi = document.createElement('li'); oLi.innerHTML = '