在上一章中有讲到文档的插入操作是用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中必需有数组中的每一个才符合结果

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

  1. MongoDB学习笔记——文档操作之查询

    查询文档 使用db.COLLECTION_NAME.findOne()可以查询所有满足条件的第一条数据 预发格式如下: db.COLLECTION_NAME.findOne(<query> ...

  2. MongoDB学习笔记——文档操作之增删改

    插入文档 使用db.COLLECTION_NAME.insert() 或 db.COLLECTION_NAME.save() 方法向集合中插入文档 db.users.insert( { user_id ...

  3. MongoDB 集合与文档操作

    一.创建DB 1.查看DB >show dbs 2.创建DB >use mydb 3.查看当前DB >db 4.删除DB >use mydb >db.dropDataba ...

  4. MongoDB内嵌文档操作

    实体定义: [BsonIgnoreExtraElements] public class Person : BaseEntity { public string FirstName { get; se ...

  5. MongoDB系列---集合与文档操作03

    MongoDB-——Collection 学习大纲: 1.集合操作 2.文档操作 知识回顾: 上一篇我们讲述了如何对MongoDB的权限和用户进行日常的基本操作,来达到我们对数据库的基本安全保障. 一 ...

  6. MongoDB入门---文档操作之增删改

    之前的两篇文章,已经分享过关于MongoDB的集合还有数据库的各种操作,接下来就涉及到最主要的喽,那就是数据方面的操作,在这里叫做文档操作.话不多说,大家来看正文.     首先来看一下它的数据结构: ...

  7. mongodb安装,库操作,集合操作(表),文档操作(记录)

    安装 1.下载地址 https://fastdl.mongodb.org/win32/mongodb-win32-x86_64-2008plus-ssl-4.0.8-signed.msi 2.如果报没 ...

  8. MongoDB数据库文档操作

    前面的话 本文将详细介绍MongoDB数据库关于文档的增删改查 数据类型 在介绍文档操作之前,首先要了解MongoDB的数据类型 MongoDB支持许多数据类型,包括 1.字符串 - 这是用于存储数据 ...

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

    Mongoose学习参考文档 前言:本学习参考文档仅供参考,如有问题,师请雅正 一.快速通道 1.1 名词解释 Schema : 一种以文件形式存储的数据库模型骨架,不具备数据库的操作能力 Model ...

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

    一.简介 spring Data  MongoDB提供了org.springframework.data.mongodb.core.MongoTemplate对MongoDB的CRUD的操作,上一篇我 ...

随机推荐

  1. 03深入理解C指针之---变量与内存

    该系列文章源于<深入理解C指针>的阅读与理解,由于本人的见识和知识的欠缺可能有误,还望大家批评指教. C语言是一种编译型的语言,C源代码在编译成可执行文件后,经常以以下三种方式使用内存: ...

  2. CUDA程序计时

    之前写的CUDA程序,想测量一下性能,网上很多用的是CPU端计时,很不准确.翻了一下书,发现这里应该使用事件来计时. CUDA中的事件本质上是一个GPU时间戳,这个时间戳是在用户指定的时间点上记录的. ...

  3. spring+jpa+HiKariCP+P6spy SSH HiKariCP P6spy

    =============p6spy准备https://www.cnblogs.com/qgc88===================== 1.简单介绍p6spy,p6spy是一个开源项目,通常使用 ...

  4. 牛客网 牛客练习赛11 D.求距离

    D.求距离 链接:https://www.nowcoder.com/acm/contest/59/D来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒空间限制:C/C++ 32768K,其他语言6 ...

  5. Java 实现随机验证码

    许多系统的注册.登录或者发布信息模块都添加的随机码功能,就是为了避免自动注册程序或者自动发布程序的使用. 验证码实际上就是随机选择一些字符以图片的形式展现在页面上,如果进行提交操作的同时需要将图片上的 ...

  6. BZOJ——2438: [中山市选2011]杀人游戏

    http://www.lydsy.com/JudgeOnline/problem.php?id=2438 Description 一位冷血的杀手潜入 Na-wiat,并假装成平民.警察希望能在 N 个 ...

  7. Failed to check the status of the service报错解决

    报这个错误是因为我的application_context.service.xml 文件里的的dubbo声明暴露口时的ref属性写错了. <dubbo:service interface=&qu ...

  8. Laravel composer自定义命令空间,方便引用第三方库

    第一步:自定义目录 在app文件夹下新建Library目录,做为第三方库的目录 第二步: 修改composer.json文件 autoload节点下的psr-4自定义命名空间 规则: key: 命名空 ...

  9. 基于cucumber接口测试框架的扩展——测试框架总结之cucumber

    主要功能: 1.通过fiddler抓取请求,导出xml文件. 2.解析xml文件至excel,或者手工填写excel数据. 3.根据excel中的URL中地址生成的接口集合和feature内容模板生成 ...

  10. POJ 3978(求素数)

    知识点:      1.求素数的test,从2~sqrt(n):           2.假设数据非常多,能够用素数表记录,然后sum=prime[m]-prime[n]求得! ! !! !!! !! ...