MongoDB 集合与文档操作
一、创建DB
1、查看DB
>show dbs
2、创建DB
>use mydb
3、查看当前DB
>db

4、删除DB
>use mydb
>db.dropDatabase()

二、创建集合
1、查看DB的集合
>show collections
2、创建集合
db.createCollection(name, options)
> db.createCollection("mycollection")

3、重命名集合
MongoDB Enterprise > db.trs_action_dzwl_zm_1.renameCollection("trs_action_dzwl_zm")

4、删除集合
db.collection.drop()
>db.mycollection.drop()

5、固定集合

>db.createCollection("user-max",{capped:true,size:1000000,max:10000,autoIndexId:true});

6、TTL集合(TTL索引)
三、插入文档
1、插入文档
db.COLLECTION_NAME.insert(document)
>db.mycollection.insert({title:'asasca',name:'xiaofuren',like:100})

2、3.2 版本后还有以下几种语法可用于插入文档
- db.collection.insertOne():向指定集合中插入一条文档数据
- db.collection.insertMany():向指定集合中插入多条文档数据
1)插入单条
>db.mycollection.insertOne({"as":300})

2)插入多条
>db.mycollection.insertMany([{"bbb":2300},{"cccc":21425}])

四、更新文档
1、更新文档语法
db.collection.update(
<query>, //update的查询条件,类似sql update查询内where后面的。
<update>, //update的对象和一些更新的操作符(如$,$inc...)等,也可以理解为sql update查询内set后面的
{
upset:<boolean>, //可选,这个参数的意思是,如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。
multi:<boolean>, //可选,mongodb 默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。
wrietConcern:<document> //可选,抛出异常的级别。
}
)
2、更新document

>db.mycollection.update({'bbb':2300},{$set:{'bbb':'This is Tom!'}})

3、save()方法
save() 方法通过传入的文档来替换已有文档。语法格式如下:
db.collection.save(
<document>,
{
writeConcern: <document>
}
)
示例
以下实例中我们替换了 _id 为 56064f89ade2f21f36b03136 的文档数据:
>db.col.save({
"_id" : ObjectId("56064f89ade2f21f36b03136"),
"title" : "MongoDB",
"description" : "MongoDB 是一个 Nosql 数据库",
"by" : "Runoob",
"url" : "http://www.runoob.com",
"tags" : [
"mongodb",
"NoSQL"
],
"likes" : 110
})
五、删除文档
1、删除语法
如果你想删除所有数据,可以使用以下方式(类似常规 SQL 的 truncate 命令):
MongoDB 是 2.6 版本以后的,语法格式如下:
db.collection.remove(
<query>,
{
justOne: <boolean>,
writeConcern: <document>
}
)
参数说明:
- query :(可选)删除的文档的条件。
- justOne : (可选)如果设为 true 或 1,则只删除一个文档,如果不设置该参数,或使用默认值 false,则删除所有匹配条件的文档。
- writeConcern :(可选)抛出异常的级别。
2、删除选择的数据
> db.mycollection.remove({"bbb":'This is Tom!'})

3、删除所有数据
>db.mycollection.remove({})
4、新的删除方法
remove() 方法已经过时了,现在官方推荐使用 deleteOne() 和 deleteMany() 方法。
如删除集合下全部文档:
db.inventory.deleteMany({})
删除 status 等于 A 的全部文档:
db.inventory.deleteMany({ status : "A" })
删除 status 等于 D 的一个文档:
db.inventory.deleteOne( { status: "D" } )

5、remove与delete注意事项
remove() 方法 并不会真正释放空间。
需要继续执行 db.repairDatabase() 来回收磁盘空间。
> db.repairDatabase()
或者
> db.runCommand({ repairDatabase: 1 })
六、查询文档
1、find查询语法如下
db.collection.find(query, projection)
- query :可选,使用查询操作符指定查询条件
- projection :可选,使用投影操作符指定返回的键。查询时返回文档中所有键值, 只需省略该参数即可(默认省略)。
如果你需要以易读的方式来读取数据,可以使用 pretty() 方法,语法格式如下:
>db.col.find().pretty()
pretty() 方法以格式化的方式来显示所有文档。
2、find查询示例
1)插入数据
MongoDB Enterprise > db.mycollection.insertMany([{"aaa":300,"name":'xiaoli'},{"bbb":400,"name":'laowang'},{"ccc":1200,"name":'boss'}])
{
"acknowledged" : true,
"insertedIds" : [
ObjectId("5def58cc4b686e3b924617f1"),
ObjectId("5def58cc4b686e3b924617f2"),
ObjectId("5def58cc4b686e3b924617f3")
]
}
2)查询数据
MongoDB Enterprise > db.mycollection.find()
{ "_id" : ObjectId("5def58cc4b686e3b924617f1"), "aaa" : 300, "name" : "xiaoli" }
{ "_id" : ObjectId("5def58cc4b686e3b924617f2"), "bbb" : 400, "name" : "laowang" }
{ "_id" : ObjectId("5def58cc4b686e3b924617f3"), "ccc" : 1200, "name" : "boss" }
3)格式化方式查询数据
MongoDB Enterprise > db.mycollection.find().pretty()
{
"_id" : ObjectId("5def58cc4b686e3b924617f1"),
"aaa" : 300,
"name" : "xiaoli"
}
{
"_id" : ObjectId("5def58cc4b686e3b924617f2"),
"bbb" : 400,
"name" : "laowang"
}
{
"_id" : ObjectId("5def58cc4b686e3b924617f3"),
"ccc" : 1200,
"name" : "boss"
}
3、findOne()
> db.mycollection.findOne()

4、MongoDB与RDBMS where 语句比较
| 操作 | 格式 | 范例 | SQL |
| 等于 | {key:value} | db.col.find({"name":"xiaoli"}) | where name='xiaoli' |
| 小于 | {key:{$lt:value}} | db.col.find({"class":{$lt:4}}) | where class<4 |
| 小于或等于 | {key:{$lte:value}} | db.col.find({"class":{$lte:4}}) | where class<=4 |
| 大于 | {key:{$gt:value}} | db.col.find({"class":{$gt:4}}) | where class>4 |
| 大于或等于 | {key:{$gte:value}} | db.col.find({"class":{$gte:4}}) | where class>=4 |
| 不等于 | {key:{$ne:value}} | db.col.find({"class":{$ne:4}}) | where class !=4 |
5、MongoDB AND OR 条件
1)AND条件
>db.col.find({"name":"xiaoli","class":4}).pretty
2)OR条件
>db.col.find({$or:[{"name":"xiaoli"},{"class":4}]})
3)AND与OR结合使用
>db.col.find({"class":{$gt:4},$or[{"name":"xiaoli"},{"name":"dawang"}]})
where class>4 and (name="xiaoli" or name="dawang")
MongoDB 集合与文档操作的更多相关文章
- MongoDB系列---集合与文档操作03
MongoDB-——Collection 学习大纲: 1.集合操作 2.文档操作 知识回顾: 上一篇我们讲述了如何对MongoDB的权限和用户进行日常的基本操作,来达到我们对数据库的基本安全保障. 一 ...
- MongoDB学习笔记——文档操作之查询
查询文档 使用db.COLLECTION_NAME.findOne()可以查询所有满足条件的第一条数据 预发格式如下: db.COLLECTION_NAME.findOne(<query> ...
- MongoDB学习笔记——文档操作之增删改
插入文档 使用db.COLLECTION_NAME.insert() 或 db.COLLECTION_NAME.save() 方法向集合中插入文档 db.users.insert( { user_id ...
- MongoDB内嵌文档操作
实体定义: [BsonIgnoreExtraElements] public class Person : BaseEntity { public string FirstName { get; se ...
- mongodb安装,库操作,集合操作(表),文档操作(记录)
安装 1.下载地址 https://fastdl.mongodb.org/win32/mongodb-win32-x86_64-2008plus-ssl-4.0.8-signed.msi 2.如果报没 ...
- MongoDB数据库、集合、文档的操作
MongoDB系列第一课:MongDB简介 MongoDB系列第二课:MongDB环境搭建 MongoDB系列第三课:MongDB用户管理 MongoDB系列第四课:MongoDB数据库.集合.文档的 ...
- MongoDB模拟多文档事务操作
Mongodb不支持多文档原子性操作,因此依据两阶段提交协议(Two Phase Commits protocol)来模拟事务. 以两个银行账户之间的转账行为为例,来说明如何实现多文档间的事务操作. ...
- MongoDB入门---文档操作之增删改
之前的两篇文章,已经分享过关于MongoDB的集合还有数据库的各种操作,接下来就涉及到最主要的喽,那就是数据方面的操作,在这里叫做文档操作.话不多说,大家来看正文. 首先来看一下它的数据结构: ...
- MongoDB数据库文档操作
前面的话 本文将详细介绍MongoDB数据库关于文档的增删改查 数据类型 在介绍文档操作之前,首先要了解MongoDB的数据类型 MongoDB支持许多数据类型,包括 1.字符串 - 这是用于存储数据 ...
随机推荐
- List集合转换为数组类型方法
list集合转换为数组可以使用list集合的toArray(T[] a)方法, topicDetailsVo.setUrl(urls.toArray(new String[]{})); url是个数组 ...
- javascript 之 扩展对象
注意点:在js中常见的几种方进行扩展 第一种:ES6提供的 Object.assign(); 第二种:ES5提供的 extend()方法 第三种:Object对象提供的 defineProperty( ...
- Python——pip的安装与使用
pip 是 Python 包管理工具,该工具提供了对Python 包的查找.下载.安装.卸载的功能.目前如果你在 python.org 下载最新版本的安装包,则是已经自带了该工具.Python 2.7 ...
- J.U.C之重入锁:ReentrantLock
此篇博客所有源码均来自JDK 1.8 ReentrantLock,可重入锁,是一种递归无阻塞的同步机制.它可以等同于synchronized的使用,但是ReentrantLock提供了比synchro ...
- 转载 AI-Talking 图算法
https://mp.weixin.qq.com/s/2XRgJr-ydxHA3JxAZ_5HeA 图算法在风控业务的实践 直播行业中有很多业务风控问题,比如说批量注册.刷热度.垃圾信息以及薅羊毛等. ...
- FreeRTOS 中断配置和临界段
中断屏蔽寄存器 PRIMASK.FAULTMASK和BASEPRI 1.PRIMASK:这是个只有1个位的寄存器.当它置1时, 就关掉所有可屏蔽的异常,只剩下 NMI和硬fault可以响应.它的缺省值 ...
- Python中@staticmethod和@classmethod的作用和区别
简单介绍一下两者的区别: 对于一般的函数test(x),它跟类和类的实例没有任何关系,直接调用test(x)即可 #!/usr/bin/python # -*- coding:utf-8 -*- de ...
- __init__、__new__方法详解
__init__详解 class Dog(object): def __init__(self): print('init方法') def __del__(self): print('del方法') ...
- Android笔记(二十一) Android中的Adapter
Android中有一些View是包含多个元素的,例如ListView,GridView等,为了给View的每一个元素都设置数据,就需要Adapter了. 常用的Adapter包括ArrayAdapte ...
- 【HCIA Gauss】学习汇总-数据库管理(数据库设计 范式 索引 分区)-7
zsql user/pasword@ip:port -c "show databases" # 展示一条sql语句 spool file_path 指定输出文件 可以为相对路径 s ...