MongoDB学习笔记——文档操作之增删改
插入文档
使用db.COLLECTION_NAME.insert() 或 db.COLLECTION_NAME.save() 方法向集合中插入文档
db.users.insert( {
user_id: "abc123",
age: 55,
status: "A"
} )
在插入的文档中,如果没有指定 _id 参数,MongoDB 会自动为文档指定一个唯一的 ID。
使用db.COLLECTION_NAME.insert() 方法传入一个文档数组,进行批量插入
db.users.insert( [{
user_id: "abc123",
age: 55,
status: "A"
},{
user_id: "abc3",
age: 55,
status: "A"
},{
user_id: "abc13",
age: 55,
status: "A"
}] )
也可以使用db.users.save(document) 插入文档。如果没有指定文档的 _id,那么 save() 就和 insert() 完全一样了。如果指定了文档的 _id,那么它会覆盖掉含有 save() 方法中指定的 _id的文档的全部数据。
更新文档
使用db.COLLECTION_NAME.update() 或 db.COLLECTION_NAME.save() 方法来更新集合中的文档
update 语法格式
db.COLLECTION_NAME.update(
<query>,
<update>,
{
upsert: <boolean>,
multi: <boolean>,
writeConcern: <document>
}
)
参数说明:
- query : update的查询条件,类似sql update查询内where后面的。
- update : update的对象和一些更新的操作符(如$,$inc...)等,也可以理解为sql update查询内set后面的
- upsert : 可选,这个参数的意思是,如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。
- multi : 可选,mongodb 默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。
- writeConcern :可选,抛出异常的级别。
db.users.update({'user_id':"abc13"},{$set:{'age':77}})
save语法格式
db.COLLECTION_NAME.save 方法利用传入该方法的文档来替换已有文档(通俗解释:如果save方法传入的文档结构A与原文档结构B不一致时,则会使用新的文档结构A替换原来的文档结构B)。如果没有指定文档的 _id,那么 save() 就和 insert() 完全一样了。如果指定了文档的 _id,那么它会覆盖掉含有 save() 方法中指定的 _id的文档的全部数据
db.COLLECTION_NAME.save(
<document>,
{
writeConcern: <document>
}
)
参数说明:
- document : 文档数据。
- writeConcern :可选,抛出异常的级别。
db.users.save({"_id" : ObjectId("582194dd7f953cec73197bb1"),'status':"OK"})
删除文档
使用db.COLLECTION_NAME.remove() 方法来删除集合中的文档
remove 语法格式
db.COLLECTION_NAME.remove(
<query>,
{
justOne: <boolean>,
writeConcern: <document>
}
)
参数说明:
- query :(可选)删除的文档的条件
- justOne : (可选)如果设为 true 或 1,则只删除一个文档。
- writeConcern :(可选)抛出异常的级别。
db.users.remove({"status" : 'OK'})
如果你只想删除第一条找到的记录可以设置 justOne 为 1
db.COLLECTION_NAME.remove(query,1)
如果想删除集合中的所有数据可以通过以下方式处理(相当于关系型数据库中的truncate 命令)
db.COLLECTION_NAME.remove({})
关系型数据库与MongoDB数据库在一些术语上的对比
|
关系型数据库(mysql) |
MongoDB |
备注 |
|
insert into `testdb`.`users` (`user_id`,`age`,`status`) values (1,100,"A"); |
db.users.insert( { user_id: "abc123", age: 55, status: "A" } ) 或 db.users.save( { user_id: "abc123", age: 55, status: "A" } ) |
|
|
update `testdb`.`users` set age=50 where age=100 |
db.users.update({'age':100},{$set:{'age':50}},{multi:true}) |
根据主键更新全表数据时可以使用db.COLLECTION_NAME.save()语法,部分字段更新不建议使用 |
|
update `testdb`.`users` set age=50 where age=100 limit 1 |
db.users.update({'age':100},{$set:{'age':50}},{multi:false}) |
根据主键更新全表数据时可以使用db.COLLECTION_NAME.save()语法,部分字段更新不建议使用 |
|
delete from `testdb`.`users` where age=100 limit 1 |
db.users.remove({'age':100},1) |
|
|
delete from `testdb`.`users` where age=100 |
db.users.remove({'age':100}) |
|
|
truncate `testdb`.`users` |
db.users.remove({}) |
MongoDB学习笔记——文档操作之增删改的更多相关文章
- MongoDB学习笔记——文档操作之查询
查询文档 使用db.COLLECTION_NAME.findOne()可以查询所有满足条件的第一条数据 预发格式如下: db.COLLECTION_NAME.findOne(<query> ...
- MongoDB入门---文档操作之增删改
之前的两篇文章,已经分享过关于MongoDB的集合还有数据库的各种操作,接下来就涉及到最主要的喽,那就是数据方面的操作,在这里叫做文档操作.话不多说,大家来看正文. 首先来看一下它的数据结构: ...
- mongoDB文档操作【增删改】
MongoDB 插入文档 文档的数据结构和JSON基本一样. 所有存储在集合中的数据都是BSON格式. BSON是一种类json的一种二进制形式的存储格式,简称Binary JSON. 插入文档 Mo ...
- mongodb内嵌文档的javaapi,增删改查
数据结构: {"_id" : "000000001", //Mongodb默认主键 "UID" : "000000001&quo ...
- mongoDB 文档操作_增
增加 / 插入 /保存 单文档插入 命令 db.collection.insertOne(doc) 功能 向被 use 的数据库中插入数据 实例 db.class.insertOne({"n ...
- MongoDB学习笔记二—Shell操作
数据类型 MongoDB在保留JSON基本键/值对特性的基础上,添加了其他一些数据类型. null null用于表示空值或者不存在的字段:{“x”:null} 布尔型 布尔类型有两个值true和fal ...
- MongoDB 集合与文档操作
一.创建DB 1.查看DB >show dbs 2.创建DB >use mydb 3.查看当前DB >db 4.删除DB >use mydb >db.dropDataba ...
- StyleCop学习笔记-文档规则
文档规则: .SA1600:ElementsMustBeDocumented元素必须添加注释 .SA1601: PartialElementsMustBeDocumented Partial修饰的成员 ...
- Mongodb学习笔记五(C#操作mongodb)
mongodb c# driver(驱动)介绍 目前基于C#的mongodb驱动有两种,分别是官方驱动(下载地址)和samus驱动(下载地址). 本次我们只演示官方驱动的使用方法. 官方驱动文档查看 ...
随机推荐
- HT图形组件设计之道(二)
上一篇我们自定义CPU和内存的展示界面效果,这篇我们将继续采用HT完成一个新任务:实现一个能进行展开和合并切换动作的刀闸控件.对于电力SCADA和工业控制等领域的人机交互界面常需要预定义一堆的行业标准 ...
- [操作系统实验lab2]实验报告
static void * alloc(u_int n, u_int align, int clear) { extern char end[]; int i; u_long alloced_mem; ...
- eclipse中去掉Js/javsscript报错信息
1.首先在problem>errors中删除所有js错误: 如下图 2.然后再勾选掉javascript Validator: 3.clean下项目吧,你会发现再也不出现js红叉叉了,哈哈.
- 搜索 + 剪枝 --- POJ 1101 : Sticks
Sticks Problem's Link: http://poj.org/problem?id=1011 Mean: http://poj.org/problem?id=1011&lan ...
- Oracle Fusion Applications (11.1.8) Media Pack and Oracle Application Development Framework 11g (11.1.1.7.2) for Microsoft Windows x64 (64-bit)
Oracle Fusion Applications (11.1.8) Media Pack for Microsoft Windows x64 (64-bit) 重新搜索 常见问题 提示 ...
- C#实用杂记-EF全性能优化技巧2
原文链接: http://www.cnblogs.com/zhaopei/p/5721789.html
- bootstrap学习笔记(6)
滚动监听 滚动监听有两种方式: (1)通过属性控制 向想要滚动监听的元素添加如下属性data-spy="scroll",然后添加data- ...
- java之内的工具分享,附带下载链接,方便以后自己寻找
class反编译工具:http://pan.baidu.com/s/1geYvX5L redis客户端工具:http://pan.baidu.com/s/1eRJ4ThC mysql客户端-[mysq ...
- 容器---List和AbstractList
一.前言 前面我们介绍了Collection及其抽象实现,在JAVA的容器体系里,由Collection派生出来的有两大体系,即List和Map.本文以及后续文章将重点分析List体系.本文将重点分析 ...
- 硅谷新闻2--禁止viewpager预加载
ContentFragment.java class MyOnPageChangeListener implements ViewPager.OnPageChangeListener { ..... ...