MongoDB CRUD 操作手册
基本操作
增加
在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 操作手册的更多相关文章
- Mongodb Manual阅读笔记:CH2 Mongodb CRUD 操作
2 Mongodb CRUD 操作 Mongodb Manual阅读笔记:CH2 Mongodb CRUD 操作Mongodb Manual阅读笔记:CH3 数据模型(Data Models)Mong ...
- MongoDB CRUD 操作
crud是指在做计算处理时的增加(Create).读取查询(Retrieve).更新(Update)和删除(Delete)几个单词的首字母简写.crud主要被用在描述软件系统中数据库或者持久层的基本操 ...
- 【翻译】MongoDB指南/CRUD操作(二)
[原文地址]https://docs.mongodb.com/manual/ MongoDB CRUD操作(二) 主要内容: 更新文档,删除文档,批量写操作,SQL与MongoDB映射图,读隔离(读关 ...
- 【翻译】MongoDB指南/CRUD操作(一)
[原文地址]https://docs.mongodb.com/manual/ MongoDB CRUD操作(一) 主要内容:CRUD操作简介,插入文档,查询文档. CRUD操作包括创建.读取.更新和删 ...
- 【翻译】MongoDB指南/CRUD操作(四)
[原文地址]https://docs.mongodb.com/manual/ CRUD操作(四) 1 查询方案(Query Plans) MongoDB 查询优化程序处理查询并且针对给定可利用的索引选 ...
- 【翻译】MongoDB指南/CRUD操作(三)
[原文地址]https://docs.mongodb.com/manual/ CRUD操作(三) 主要内容: 原子性和事务(Atomicity and Transactions),读隔离.一致性和新近 ...
- MongoDB的CRUD操作
1. 前言 在上一篇文章中,我们介绍了MongoDB.现在,我们来看下如何在MongoDB中进行常规的CRUD操作.毕竟,作为一个存储系统,它的基本功能就是对数据进行增删改查操作. MongoDB中的 ...
- Spring Data MongoDB 一:入门篇(环境搭建、简单的CRUD操作)
一.简介 Spring Data MongoDB 项目提供与MongoDB文档数据库的集成.Spring Data MongoDB POJO的关键功能区域为中心的模型与MongoDB的DBColle ...
- mongodb 数据操作CRUD
链接到mongo 新建超级用户 上文中我们提到mongo用户库表管理.为了方便我们先新建一个root权限的用户. db.createUser({user:'dbadmin',pwd:'123456', ...
随机推荐
- 梅须逊雪三分白,雪却输梅一段香——CSS动画与JavaScript动画
CSS动画并不是绝对比JavaScript动画性能更优越,开源动画库Velocity.js等就展现了强劲的性能. 一.两者的主要区别 先开门见山的说说两者之间的区别. 1)CSS动画: 基于CSS的动 ...
- Js 变量声明提升和函数声明提升
Js代码分为两个阶段:编译阶段和执行阶段 Js代码的编译阶段会找到所有的声明,并用合适的作用域将它们关联起来,这是词法作用域的核心内容 包括变量声明(var a)和函数声明(function a(){ ...
- 探索ASP.NET MVC5系列之~~~3.视图篇(下)---包含常用表单和暴力解猜防御
其实任何资料里面的任何知识点都无所谓,都是不重要的,重要的是学习方法,自行摸索的过程(不妥之处欢迎指正) 汇总:http://www.cnblogs.com/dunitian/p/4822808.ht ...
- 02.LoT.UI 前后台通用框架分解系列之——灵活的菜单栏
LOT.UI分解系列汇总:http://www.cnblogs.com/dunitian/p/4822808.html#lotui LoT.UI开源地址如下:https://github.com/du ...
- clr 元数据
clr相关编译器编译生成的托管模块由四部分组成:PE32或32+头.clr头.元数据.IL代码. 元数据和IL代码完全对应,保持一致(:>)性. 元数据有很多用途: VS的智能感知,自动补全: ...
- AES加密
package com.edu.hpu; import java.math.BigInteger; import java.security.MessageDigest; import java.se ...
- 一起学微软Power BI系列-使用技巧(3)Power BI安卓手机版安装与体验
Power BI有手机版,目前支持安卓,苹果和WP,不过没有WP手机,苹果在国内还不能用,要FQ和用就不测试了.安卓的我也也是费了九牛二虎之力才把app下载下来,把方法分享给大家. FQ太麻烦,所以建 ...
- python 数据类型 ---文件一
1.文件的操作流程: 打开(open), 操作(read,write), 关闭(close) 下面分别用三种方式打开文件,r,w,a 模式 . "a"模式将不会覆盖原来的文件内容, ...
- 总结iOS开发中的断点续传那些事儿
前言 断点续传概述 断点续传就是从文件赏赐中断的地方重新开始下载或者上传数据,而不是从头文件开始.当下载大文件的时候,如果没有实现断点续传功能,那么每次出现异常或者用户主动的暂停,都会从头下载,这样很 ...
- centos6.5 nginx-1.8.0和ftp搭建图片服务器
一.Nginx的安装步骤 1.Nginx安装环境: gcc: 安装nginx需要先将官网下载的源码进行编译,编译依赖gcc环境,如果没有gcc环境,需要安装gcc:yum install gcc-c+ ...