MongoDB的增删改查

(黎明你好原创作品,转载请注明)

MongoDB中数据的基本单元叫做文档,采用json的键-值的方式。多个键及其关联的值有序的存放在一起变是文档。类似于编程语言中的键值关系。MongoDB文档都是BSON文档,他是一个JSON的二进制形式。

MongoDB的文档

MongoDB中文档被存储在集合中。集合是一组有关系索引的文档。集合类似于关系数据库中的表。

MongoDB的集合

2.1 方法参考

查询游标方法

名称 说明
cursor.count() 返回游标中的文档的数量。
cursor.explain() 报告的查询执行计划,包括索引使用的游标。
cursor.hint() 若要使用查询的特定索引的部队 MongoDB。
cursor.limit() 约束游标的结果集的大小。
cursor.next() 返回游标中的下一个文档。
cursor.skip() 返回一个游标,开始传递或跳过的一些文件后才返回结果。
cursor.sort() 返回结果排序根据排序的规范。
cursor.toArray() 返回一个数组,包含由光标返回的所有文档。
名称 说明
db.collection.insert() 在集合中创建一个新文档。
db.collection.save() 提供insert()和update ()插入新文件的包装。
db.collection.update() 修改集合中的文档。
db.collection.find() 集合上执行查询,并返回一个游标对象。
db.collection.findOne() 执行查询,并返回一个单独的文档。
db.collection.remove() 从集合中删除的文件。
db.collection.count() 换行计数集合或匹配查询中返回的文档数的计数。
db.collection.distinct() 返回一个数组没有指定的字段不重复值的文件。

2.2 Insert()

  1. db.collection.insert(document)

Insert()方法有以下行为:

如果该集合不存在,insert()方法将创建集合。

如果文档没有指定一个_id后缀字段,然后 MongoDB 将添加一个_id字段并使用ObjectId为文档分配取值。

如果文档需要增加一个新的字段,则insert()方法可以为文档插入新的字段。这不需要更改集合的数据模型或现有的文档。

  1. db.user.insert({_id: "1", name:{username: "limingnihao", nickname: "黎明你好"}, password: "123456"})
  2. db.user.insert({_id: "2", name:{username: "zhoujielun", nickname: "周杰伦"}, password: "123456", birth: ISODate('1979-01-18')})
  3. db.user.insert({_id: "3", name:{username: "caiyilin", nickname: "蔡依林"}, password: "123456", birth: ISODate('1980-09-15'), special:["看我72变", "花蝴蝶", "特务J"], regionName: "台湾"})

2.3 Save()

  1. db.collection.save(document)

插入一个新的文档,或者根据其文档的参数更新现有的文档。

如果文档不包含一个_id的字段进行save时,mongod将向文档中添加一个_id字段并将其分配一个ObjectId。

如果文档中包含一个_id字段和值进行save ()方法时,则在集合中查询此_id的文档执行的是upsert操作。如果集合中不存在具有指定的_id值的文档,save ()方法执行的是insert操作。save ()方法执行时会将现有文档中的所有字段都替换为新文档中字段。

  1. db.user.save({_id: "1", name:{username: "limingnihao", nickname: "黎明你好"}, password: "123456", birth: ISODate('1985-07-15')})

2.4 Update()

  1. db.collection.update( <query>, <update>, <upsert>, <multi> )

修改现有存在的文档或集合时使用。

默认的update()方法值更新单个文档。但是如果multi参数设置为true,则更新操作可以更新全部符合条件的文档。

Query – 类型:文档;用于更新选择过滤。

Update – 类型:文档;需要更新的文档的内容。

Upsert – 类型:文档或boolean;设置为true时,当查询没有匹配到文档时进行新建。默认值为false

Multi: - 类型:文档或boolean;设置为true时,则更新满足查询条件的所有文档(多个)。设置为false时只更新单个文档。默认为false。

字段更新操作方式

名字 说明
$inc 用来增加已有键的值,或者在键不存在时创建一个键。是专门来增加(和减少)数字的。只能用于整数、长整数或双精度浮点数。要是用在其他类型的数据上就会导致操作失败。
$rename 重命名字段。新的字段名称不能和文档中现有的字段名相同。
$setOnInsert 执行insert操作时,操作给相应的字段赋值。
$set 用来指定一个键的值。如果这个键不存在,则创建它。
$unset 从文档中移除指定的键。
  1. db.user.update({_id: "1"}, {$inc:{age: 1}}, {multi:true})
  2. db.user.update({_id: "1"}, { $rename: { 'password': 'pwd'}})
  3. db.user.update({_id: "4"}, { $setOnInsert: { works: 5}}, {upsert: true})
  4. db.user.update({_id: "1"}, {$set:{password: "654321", age: 28}})
  5. db.user.update({_id: "4"},{$unset: {"works": 5 }})

2.5 Find()

  1. db.collection.find(<criteria>, <projection>)
  2. db.collection.findOne(<criteria>, <projection>)

Criteria - 类型:文档;可选,文档的查询过滤条件。

Projection - 类型:文档,对结果进行字段匹配,{ field1: <boolean>, field2: <boolean> ... }。

后面还可以:Sort()排序、Limit()限制个数、Skip()起始点。

  1. db.collection.find(<criteria>, <projection>)返回集合
  2. db.collection.findOne(<criteria>, <projection>)返回一个
  3. db.user.find({_id: "1"})
  4. db.user.find({works: 5})
  5. db.user.find().sort({age:1})
  6. db.user.find().limit(2).sort({age:1})
  7. db.user.find().skip(1).limit(2).sort({age:1})

2.6 Remove()

  1. db.collection.remove(query, justOne)

Query – 类型:文档;用于删除选择过滤。

JustOne – 类型:boolean;当设置为true时只删除一个文档。

  1. db.user.remove({_id: "4"}, true)

2.7 Count()

  1. db.collection.count(<query>)

Query – 类型:文档;用于查询选择过滤。

  1. db.user.count({age: 1})

2.8 Distinct()

  1. db.collection.distinct(field, query)

Field – 类型:字符串;返回非重复的字段。

Query – 类型:文档;查询条件。

  1. db.user.distinct("_id", {age: 1})
 

MongoDB的增删改查 转的更多相关文章

  1. Java连接MongoDB进行增删改查

    1.导入必须的包: 详情看项目:http://pan.baidu.com/s/1cvDAOY 2.通过Myeclipse创建WEB项目 3. 3.bean:创建实体类 package com.bean ...

  2. Java实现mongodb原生增删改查语句

    Java实现mongodb原生增删改查语句 2018-03-16 自动化测试时,需校验数据库数据,为了快速自动化,在代码中用原生增删改查语句操作mongodb 结构 代码 0 pom.xml < ...

  3. Scala对MongoDB的增删改查操作

    =========================================== 原文链接: Scala对MongoDB的增删改查操作 转载请注明出处! ==================== ...

  4. C# 对MongoDB 进行增删改查的简单操作

    C# 对MongoDB 进行增删改查的简单操作   下面演示下C#操作MongoDB驱动的简单的增删改查代码 运用到的MongoDB支持的C#驱动,当前版本为1.6.0 1,连接数据库   /// & ...

  5. python操作三大主流数据库(8)python操作mongodb数据库②python使用pymongo操作mongodb的增删改查

    python操作mongodb数据库②python使用pymongo操作mongodb的增删改查 文档http://api.mongodb.com/python/current/api/index.h ...

  6. python 全栈开发,Day124(MongoDB初识,增删改查操作,数据类型,$关键字以及$修改器,"$"的奇妙用法,Array Object 的特殊操作,选取跳过排序,客户端操作)

    一.MongoDB初识 什么是MongoDB MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写.旨在为 WEB 应用提供可扩展的高性能数据存储解决方案. MongoDB 是一个介 ...

  7. 2,MongoDB之增删改查及pymongo的使用

    本章我们来学习一下关于 MongoDB的增删改查 一.MongoDB操作 之 原生ORM,根本不存在SQL语句 创建数据库:这里和一般的关系型数据库一样,都要先建立一个自己的数据库空间 是的,Mong ...

  8. SpringBoot操作MongoDB实现增删改查

    本篇博客主讲如何使用SpringBoot操作MongoDB. SpringBoot操作MongoDB实现增删改查 (1)pom.xml引入依赖 <dependency> <group ...

  9. MongoDB之增删改查(一)

    本文主要介绍MongoDB数据库增删改查操作. 增 mongoDB和其它关系型数据库一样,通过insert来添加数据到集合中去. db.collectionName.insert(内容) 显示数据库中 ...

随机推荐

  1. scala学习之第二天:可变容器与不可变容器的特性与应用

    1.具体的不可变集合实体类 List(列表) 是一种有限的不可变序列式.提供了常数时间的访问列表头元素和列表尾的操作,并且提供了常数时间的构造新链表的操作,该操作将一个新的元素插入到列表的头部.其他许 ...

  2. [转]php返回json数据中文显示的问题

    转自 : http://blog.csdn.net/superbirds/article/details/8091910 解决方法:   <?php    function Notice(){  ...

  3. Integrating JAD decompiler into JDeveloper(转)

    原文地址:Integrating JAD decompiler into JDeveloper In JDeveloper, when debugging or otherwise navigatin ...

  4. python实现概率分布

    1. 二项分布(离散) import numpy as np from scipy import stats import matplotlib.pyplot as plt ''' # 二项分布 (b ...

  5. IT应届生如何准备找工作?

    今天和一个弟弟吃饭,他明年年初即将计算机研究生毕业.谈论到怎么找工作,觉得自己会的不多,心里非常发虚.虽然我当年找工作也走了很多弯路,思路并不是很清晰.但是工作了这么多年,对企业需要什么样子的人还是有 ...

  6. CodeIgniter框架入门教程——第一课 Hello World!

    本文转载自:http://www.softeng.cn/?p=45 今天开始,我将在这里连载由我自己编写的<CodeIgniter框架入门教程>,首先,这篇教程的读着应该是有PHP基础的编 ...

  7. IT技术的进化道路

    IT技术是人类发明的,同时也是给人类服务的,这项技术的进化,就是距离人越来越近,大体上是: 大型机时代: 离人类的距离超过100米. 小型机时代: 离人类的距离前进到10米. PC机时代: 离人类的距 ...

  8. 关于hangfire的使用

    hangfire 是一个分布式后台执行服务.用它可以代替ThreadPool.QueunItemWork等原生方法.当然4.5后的 task也是相当好用且功能强大.不过如果想分布式处理并且可监控的话, ...

  9. jquery的常用的容易忘记的东西

    1.浅谈jQuery中 wrap() wrapAll() 与 wrapInner()的差异  http://www.jb51.net/article/57336.htm 2. jquery的each方 ...

  10. [POJ3177]Redundant Paths(双联通)

    在看了春晚小彩旗的E技能(旋转)后就一直在lol……额抽点时间撸一题吧…… Redundant Paths Time Limit: 1000MS   Memory Limit: 65536K Tota ...