当前位置:网站首页>『MongoDB』你想要的MongoDB基本操作这里都有
『MongoDB』你想要的MongoDB基本操作这里都有
2022-07-26 21:47:00 【华为云】

读完这篇文章里你能收获到
- MongoDB的初步了解
- MongoDB数据库的操作
- MongoDB集合操作
- MongoDB文档的增删改查
- MongoDB文档的分页查询

一、简介
MongoDB是一个基于分布式文件存储的数据库。由C++语言编写,旨在为WEB应用提供可扩展的高性能数据存储解决方案。MongoDB是一个介于关系型数据库和非关系型数据库之间的产品,是非关系型数据库当中功能最丰富,最像关系型数据库的。

二、相关概念
MongoDB是非关系型数据库当中最像关系型数据库的,所以我们通过它与关系型数据库的对比,来了解下它的概念。


三、数据库操作
- 创建数据库,使用
use命令去创建数据库,当插入第一条数据时会创建数据库,例如创建一个test数据库
use test db.article.insert({name:"MongoDB 教程"})- 删除数据库,使用db对象中的
dropDatabase()方法来删除;
use test db.dropDatabase()
四、集合操作
- 创建集合,使用db对象中的
createCollection()方法来创建集合,例如创建一个article集合
use test db.createCollection("article")- 删除集合,使用collection对象的drop()方法来删除集合,例如删除一个article集合
use test db.article.drop()
五、文档操作
5.1 插入文档
- MongoDB通过collection对象的
insert()方法向集合中插入文档,语法如下
db.collection.insert(document)- 使用collection对象的
insert()方法来插入文档,例如插入一个article文档
db.article.insert({title: 'MongoDB 教程', description: 'MongoDB 是一个 Nosql 数据库', by: 'Andy', url: 'https://www.mongodb.com/', tags: ['mongodb', 'database', 'NoSQL'], likes: 100})- 使用collection对象的find()方法可以获取文档,例如获取所有的article文档
db.article.find({})5.2 更新文档
- MongoDB通过collection对象的
update()来更新集合中的文档,语法如下;
db.collection.update( <query>, <update>, { multi: <boolean> })# query:修改的查询条件,类似于SQL中的WHERE部分# update:更新属性的操作符,类似与SQL中的SET部分# multi:设置为true时会更新所有符合条件的文档,默认为false只更新找到的第一条- 将title为
MongoDB 教程的所有文档的title修改为MongoDB;
db.article.update({'title':'MongoDB 教程'},{$set:{'title':'MongoDB'}},{multi:true})save()方法可以用来替换已有文档,语法如下
db.collection.save(document)这次我们将ObjectId为5e9943661379a112845e4056的文档的内容更新;
db.article.save({ "_id" : ObjectId("5e9943661379a112845e4056"), "title" : "MongoDB 教程", "description" : "MongoDB 是一个 Nosql 数据库", "by" : "Andy", "url" : "https://www.mongodb.com/", "tags" : [ "mongodb", "database", "NoSQL" ], "likes" : 100.0})5.3 删除文档
- MongoDB通过collection对象的remove()方法来删除集合中的文档,语法如下;
db.collection.remove( <query>, { justOne: <boolean> })# query:删除的查询条件,类似于SQL中的WHERE部分# justOne:设置为true只删除一条记录,默认为false删除所有记录- 删除title为MongoDB 教程的所有文档;
db.article.remove({'title':'MongoDB 教程'})5.4 查询文档
- MongoDB通过collection对象的find()方法来查询文档,语法如下;
db.collection.find(query, projection)# query:查询条件,类似于SQL中的WHERE部分# projection:可选,使用投影操作符指定返回的键查询article集合中的所有文档;
db.article.find()- MongoDB中的条件操作符,通过与SQL语句的对比来了解下;

- 条件查询,查询title为MongoDB 教程的所有文档;
db.article.find({'title':'MongoDB 教程'})- 条件查询,查询likes大于50的所有文档;
db.article.find({'likes':{$gt:50}})AND条件可以通过在find()方法传入多个键,以逗号隔开来实现,例如查询title为MongoDB 教程并且by为Andy的所有文档;
db.article.find({'title':'MongoDB 教程','by':'Andy'})OR条件可以通过使用$or操作符实现,例如查询title为Redis 教程或MongoDB 教程的所有文档;
db.article.find({$or:[{"title":"Redis 教程"},{"title": "MongoDB 教程"}]})AND和OR条件的联合使用,例如查询likes大于50,并且title为Redis 教程或者MongoDB 教程的所有文档。
db.article.find({"likes": {$gt:50}, $or: [{"title": "Redis 教程"},{"title": "MongoDB 教程"}]})5.5 Limit与Skip
- 读取指定数量的文档,可以使用
limit()方法,语法如下;
db.collection.find().limit(NUMBER)- 只查询article集合中的2条数据;
db.article.find().limit(2)- 跳过指定数量的文档来读取,可以使用
skip()方法,语法如下;
db.collection.find().limit(NUMBER).skip(NUMBER)- 从第二条开始,查询article集合中的2条数据;
db.article.find().limit(2).skip(1)5.6 排序
- 在MongoDB中使用
sort()方法对数据进行排序,sort()方法通过参数来指定排序的字段,并使用1和-1来指定排序方式,1为升序,-1为降序;
db.collection.find().sort({KEY:1})- 按article集合中文档的likes字段降序排列;
db.article.find().sort({likes:-1})5.7 索引
- 索引通常能够极大的提高查询的效率,如果没有索引,MongoDB在读取数据时必须扫描集合中的每个文件并选取那些符合查询条件的记录。
- MongoDB使用createIndex()方法来创建索引,语法如下;
db.collection.createIndex(keys, options)# background:建索引过程会阻塞其它数据库操作,设置为true表示后台创建,默认为false# unique:设置为true表示创建唯一索引# name:指定索引名称,如果没有指定会自动生成给title和description字段创建索引,1表示升序索引,-1表示降序索引,指定以后台方式创建;
db.article.createIndex({"title":1,"description":-1}, {background: true})查看article集合中已经创建的索引;
db.article.getIndexes()/* 1 */[ { "v" : 2, "key" : { "_id" : 1 }, "name" : "_id_", "ns" : "test.article" }, { "v" : 2, "key" : { "title" : 1.0, "description" : -1.0 }, "name" : "title_1_description_-1", "ns" : "test.article", "background" : true }]5.8 聚合
- MongoDB中的聚合使用
aggregate()方法,类似于SQL中的group by语句,语法如下;
db.collection.aggregate(AGGREGATE_OPERATION)聚合中常用操作符如下;
- 根据by字段聚合文档并计算文档数量,类似与SQL中的
count()函数;
db.article.aggregate([{$group : {_id : "$by", sum_count : {$sum : 1}}}])/* 1 */{ "_id" : "Andy", "sum_count" : 2.0}/* 2 */{ "_id" : "Ruby", "sum_count" : 1.0}- 根据by字段聚合文档并计算likes字段的平局值,类似与SQL中的
avg()语句;
db.article.aggregate([{$group : {_id : "$by", avg_likes : {$avg : "$likes"}}}])/* 1 */{ "_id" : "Andy", "avg_likes" : 100.0}/* 2 */{ "_id" : "Ruby", "avg_likes" : 100.0}5.9 正则表达式
MongoDB使用
$regex操作符来设置匹配字符串的正则表达式,可以用来模糊查询,类似于SQL中的like操作;例如查询title中包含教程的文档;
db.article.find({title:{$regex:"教程"}})- 不区分大小写的模糊查询,使用
$options操作符;
db.article.find({title:{$regex:"elasticsearch",$options:"$i"}})边栏推荐
猜你喜欢

动态规划之线性DP

【Qt多线程之线程的等待和唤醒】

08.02 adjacency table

Understand China's financial system in one article

Matlab draw short-term energy diagram

博途PLC输出通道映射FC

Spend 120 billion to build a "subway" to connect 4 trillion cities. What is Guangdong thinking?

leetcode:857. 雇佣 K 名工人的最低成本【分块思考 + 由简单入手】

yolov1

2018 arXiv preprint | MolGAN: An implicit generative model for small molecular graphs
随机推荐
【Io开发笔记】机智云智能浇花器实战(3)-自动生成代码移植
恋爱时各个顺序整理(历时两个月详细整理)
Nacos作为注册中心、配置中心入门使用篇-实现远程调用、动态获取配置文件、数据库配置信息
LeetCode 122:买卖股票的最佳时机 II
Classification of banking business
LeetCode 121:买卖股票的最佳时机
【地平线旭日X3派试用体验】+开箱帖
JWT implements login authentication + token automatic renewal scheme, which is the correct posture!
什么是 Base64 ?
leetcode:857. 雇佣 K 名工人的最低成本【分块思考 + 由简单入手】
软件测试技术之跨平台的移动端UI自动化测试(下)
模块8(消息队列存储消息数据的mysql表格)
Protobuf之proto基础语法
在灯塔工厂点亮5G,宁德时代抢先探路中国智造
缓存数据库Memcached
unity 安装失败:operation not permitted, mkdir......
博途PLC输出通道映射FC
Blog Garden beautification skills summary
Leetcode:857. Minimum cost of employing K workers [think in blocks + start with simplicity]
DAO 的发展状态
