基本操作

增加

在MongoDB中通过db.collection.insert()来增加新的数据。

db.users.insert({username:"Jack",age:30})

操作完成之后会返回一条WriteResult对象,这个对象包含了操作的状态。

WriteResult({"nInserted" : 1 })

如果插入失败,WriteResult会包含错误信息。

通过 db.collection.find() 来查找所有插入的文档信息。

批量增加

db.collection.insert()支持批量操作。

可以先创建数组,然后一次性插入。

var users=
[
{
username:"Frank",
age:20
},
{
username:"Bob",
age:22
},
{
username:"Lucy",
age:21
}
] db.users.insert(users)

操作完成之后,会返回一个BulkWriteResult对象,来反馈本次操作的相关信息。

除了以上这种操作,MongoDB(2.6版本之后)还提供了另外一种批量操作Bulk()函数。

通过db.collection.initializeOrderedBulkOp(),初始化一个Bulk操作块。

var bulk = db.users.initializeUnorderedBulkOp();

bulk.insert(
{
username:"James",
age:30
}
);
bulk.insert(
{
username:"Wade",
age:31
}
); //commit operation
bulk.execute()

同样,这个操作也会返回 BulkWriteResult 对象反馈相关信息。

查询操作

通过db.collection.find() 可以查到集合下的所有数据。

db.users.find({})
db.users.find()

条件查询

db.users.find({age:10})

使用 $in 关键字选取符合后面列表条件的数据

db.users.find( { age: { $in: [ 30, 20 ] } } )

多个条件

db.users.find( { age: 30, username: 'James' } )

当一个条件成立的时候,使用 $or 查询

db.users.find({
$or: [ { username: "James", age:30} ]
})

修改数据

通过update函数来更新数据,第一个参数去选取需要匹配的数据,然后用 $set 关键字,来更新需要更新的数据字段。最后使用 currentDate来修改这个数据的修改时间。

db.users.update(
{ age:20 },
{
$set:{
age:25
},
$currentDate : {lastModified:true}
}
)

操作会返回一个WriteResult对象来解释这次操作的状态。

更新一个嵌套的数据

db.doc.insert(
{
bookname:"Rework",
detail:{
model: "14Q3",
manufacturer: "XYZ Company"
}
}
) db.doc.update(
{ bookname:"Rework" },
{ $set:{"details.model": "14Q2"} }
)

操作会返回一个WriteResult对象来解释这次操作的状态。

默认情况下,MongoDB只会更新一条数据,如果更新多条数据,需要在更新是指定参数。

db.users.update(
{ age:20 },
{
$set:{
age:25
},
$currentDate : {lastModified:true}
},
{ multi: true }
)

替换数据

替换数据会替换文档中,除了_id字段之外的所有数据。

db.users.update(
{ name: "none" },
{
name:"Kids",
age:12
}
)

默认情况下,如果update方法没有匹配到任何数据,那么update方法就不会做任何事情。然而使用upsert关键字,那么如果没有匹配到数据,会自动新增一条新的数据到集合中。

db.users.update(
{ name:"one" },
{
name:"Kids",
age:12
},
{ upsert : true }
)

操作会返回一个WriteResult对象来解释这次操作的状态,这里会带有新的数据的id值。

删除数据

使用remove()函数删除所有的数据.

db.users.remove({})

remove()操作比drop()操作更加有效率。

按条件删除

db.users.remove({age:30})

只删除查找到的数据中得第一条数据。

db.users.remove({age:30},true)

有限查询

返回所有的字段

db.users.find({age:20})

返回指定的字段

db.users.find( { age : 20 }, { age:true, username:true } )

默认总是会有_id字段,除非自己特意指定

db.users.find( { age : 20 }, { age:true, username:true, _id:false } )

除去特定字段,全部返回

db.users.find( { age : 20 }, { age:false} )

MongoDB CRUD 操作手册的更多相关文章

  1. Mongodb Manual阅读笔记:CH2 Mongodb CRUD 操作

    2 Mongodb CRUD 操作 Mongodb Manual阅读笔记:CH2 Mongodb CRUD 操作Mongodb Manual阅读笔记:CH3 数据模型(Data Models)Mong ...

  2. MongoDB CRUD 操作

    crud是指在做计算处理时的增加(Create).读取查询(Retrieve).更新(Update)和删除(Delete)几个单词的首字母简写.crud主要被用在描述软件系统中数据库或者持久层的基本操 ...

  3. 【翻译】MongoDB指南/CRUD操作(二)

    [原文地址]https://docs.mongodb.com/manual/ MongoDB CRUD操作(二) 主要内容: 更新文档,删除文档,批量写操作,SQL与MongoDB映射图,读隔离(读关 ...

  4. 【翻译】MongoDB指南/CRUD操作(一)

    [原文地址]https://docs.mongodb.com/manual/ MongoDB CRUD操作(一) 主要内容:CRUD操作简介,插入文档,查询文档. CRUD操作包括创建.读取.更新和删 ...

  5. 【翻译】MongoDB指南/CRUD操作(四)

    [原文地址]https://docs.mongodb.com/manual/ CRUD操作(四) 1 查询方案(Query Plans) MongoDB 查询优化程序处理查询并且针对给定可利用的索引选 ...

  6. 【翻译】MongoDB指南/CRUD操作(三)

    [原文地址]https://docs.mongodb.com/manual/ CRUD操作(三) 主要内容: 原子性和事务(Atomicity and Transactions),读隔离.一致性和新近 ...

  7. MongoDB的CRUD操作

    1. 前言 在上一篇文章中,我们介绍了MongoDB.现在,我们来看下如何在MongoDB中进行常规的CRUD操作.毕竟,作为一个存储系统,它的基本功能就是对数据进行增删改查操作. MongoDB中的 ...

  8. Spring Data MongoDB 一:入门篇(环境搭建、简单的CRUD操作)

    一.简介 Spring Data  MongoDB 项目提供与MongoDB文档数据库的集成.Spring Data MongoDB POJO的关键功能区域为中心的模型与MongoDB的DBColle ...

  9. mongodb 数据操作CRUD

    链接到mongo 新建超级用户 上文中我们提到mongo用户库表管理.为了方便我们先新建一个root权限的用户. db.createUser({user:'dbadmin',pwd:'123456', ...

随机推荐

  1. ArcGIS 10.0紧凑型切片读写方法

    首先介绍一下ArcGIS10.0的缓存机制: 切片方案 切片方案包括缓存的比例级别.切片尺寸和切片原点.这些属性定义缓存边界的存在位置,在某些客户端中叠加缓存时匹配这些属性十分重要.图像格式和抗锯齿等 ...

  2. Convert BSpline Curve to Arc Spline in OpenCASCADE

    Convert BSpline Curve to Arc Spline in OpenCASCADE eryar@163.com Abstract. The paper based on OpenCA ...

  3. GPG终极指南(加密/签名)

    我们平时都听过非对称加密,公钥和私钥,签名验证,但这些证书都是怎么得到的呢?本篇文章会解答这些问题. 背景介绍 加密的一个简单但又实用的任务就是发送加密电子邮件.多年来,为电子邮件进行加密的标准一直是 ...

  4. Linux常用命令操作

    系统信息 arch 显示机器的处理器架构(1) uname -m 显示机器的处理器架构(2) uname -r 显示正在使用的内核版本 dmidecode -q 显示硬件系统部件 - (SMBIOS ...

  5. SQL Server2008R2 在windows8上安装,出现“兼容性”和 “执行未经授权的操作”的错误!

    本人是windows8.1的操作系统,亲测安装成功 解决方法如下: 1.卸载干净sql Server2008r2,包括注册表内容,删除c盘下的安装路径! 2.关闭防火墙(这步很重要) 3.断开网络连接 ...

  6. Block解析(iOS)

    1. 操作系统中的栈和堆 我们先来看看一个由C/C++/OBJC编译的程序占用内存分布的结构: 栈区(stack):由系统自动分配,一般存放函数参数值.局部变量的值等.由编译器自动创建与释放.其操作方 ...

  7. mysql百万级分页优化

    普通分页 数据分页在网页中十分多见,分页一般都是limit start,offset,然后根据页码page计算start , 这种分页在几十万的时候分页效率就会比较低了,MySQL需要从头开始一直往后 ...

  8. 定时Job在IIS中潜在危险-IIS 定期回收

    引言 有时我们会在IIS中启用一些定时服务,但是你必须清楚IIS会定期回收Asp.net的应用程序的.首先来看IIS啥时候回收APPDomain.   APPDomain 回收时机 There are ...

  9. hasOwnProperty()、propertyIsEnumerable()和isPrototypeOf()的用法

    javascript中有原型这么一个概念,任何一个构造函数都有它对应的原型(prototype),我们可以给这个原型赋予一些我们想要的属性,像下面这样: function Gadget(name, c ...

  10. 你还可以再诡异点吗——SQL日志文件不断增长

    前言 今天算是遇到了一个罕见的案例. SQL日志文件不断增长的各种实例不用多说,园子里有很多牛人有过介绍,如果我再阐述这些陈谷子芝麻,想必已会被无数次吐槽. 但这次我碰到的问题确实比较诡异,其解决方式 ...