当前位置:首页 > 技术分析 > 正文内容

MongoDB快速入门,掌握这些刚刚好

ruisui882周前 (04-15)技术分析14

摘要

虽说现在关系型数据库还是主流,但是面对某些需求的时候,需要非关系型数据库来补充它,学习一个主流的NoSQL数据库还是很有必要的。MongoDB是一个功能丰富的NoSQL数据库,本文整理了它最常用的部分形成了这篇入门教程,希望对大家有所帮助。

简介

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

安装

以前写的MongoDB安装教程是基于3.2版本的,发现有的朋友使用新版本安装有问题,这次我们使用最新版本再来安装一次,本文所使用的MongoDB版本为4.2.5,总的来说,新版本的安装更简单了。

Windows下的安装

  • 下载MongoDB安装包,选择Windows x64版本安装,下载地址:www.mongodb.com/download-ce…



  • 运行MongoDB安装包并选择自定义安装,设置好安装路径;



  • 配置MongoDB,让MongoDB作为服务运行,并配置好数据目录和日志目录;



  • 取消MongoDB Compass的安装选项(不取消安装极慢),需要可自行安装;


  • 双击mongo.exe可以运行MongoDB自带客户端,操作MongoDB;



  • 连接成功后会显示如下信息;



  • 如果需要移除MongoDB服务,只需使用管理员权限运行cmd工具,并输入如下命令。
sc.exe delete MongoDB
复制代码

Linux下的安装

  • 下载MongoDB的Docker镜像;
docker pull mongo:4.2.5
复制代码
  • 使用Docker命令启动MongoDB服务;
docker run -p 27017:27017 --name mongo \
-v /mydata/mongo/db:/data/db \
-d mongo:4.2.5
复制代码
  • 有时候我们需要为MongoDB设置账号,可以使用如下命令启动;
docker run -p 27017:27017 --name mongo \
-v /mydata/mongo/db:/data/db \
-d mongo:4.2.5 --auth
复制代码
  • 然后我们需要进入容器中的MongoDB客户端;
docker exec -it mongo mongo
复制代码
  • 之后在admin集合中创建一个账号用于连接,这里创建的是基于root角色的超级管理员帐号;
use admin
db.createUser({ 
    user: 'mongoadmin', 
    pwd: 'secret', 
    roles: [ { role: "root", db: "admin" } ] });
复制代码
  • 创建完成后验证是否可以登录;
db.auth("mongoadmin","secret")
复制代码
  • 整个账号创建过程可以参考下图。



客户端工具

MongoDB的客户端工具有很多,上面没安装的MongoDB Compass就是其中之一,另外Navicat 15版本也有MongoDB的管理功能。这里我们使用的是一款免费的客户端工具Robo 3T(以前叫Robomongo)。

  • 首先下载客户端工具,下载地址:robomongo.org/download



  • 下载完成后解压,双击robo3t.exe即可使用;



  • 之后创建一个到MongoDB的连接;



  • 创建连接成功以后,就可以操作MongoDB了。



相关概念

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

SQL概念 MongoDB概念 解释/说明 database database 数据库 table collection 数据库表/集合 row document 数据记录行/文档 column field 数据字段/域 index index 索引 primary key primary key 主键,MongoDB自动将_id字段设置为主键

数据库操作

  • 创建数据库,使用use命令去创建数据库,当插入第一条数据时会创建数据库,例如创建一个test数据库;
> use test
switched to db test
> db.article.insert({name:"MongoDB 教程"})
WriteResult({ "nInserted" : 1 })
> show dbs
admin   0.000GB
config  0.000GB
local   0.000GB
test    0.000GB
复制代码
  • 删除数据库,使用db对象中的dropDatabase()方法来删除;
> db.dropDatabase()
{ "dropped" : "test", "ok" : 1 }
> show dbs
admin   0.000GB
config  0.000GB
local   0.000GB
复制代码

集合操作

  • 创建集合,使用db对象中的createCollection()方法来创建集合,例如创建一个article集合;
> use test
switched to db test
> db.createCollection("article")
{ "ok" : 1 }
> show collections
article
复制代码
  • 删除集合,使用collection对象的drop()方法来删除集合,例如删除一个article集合;
> db.article.drop()
true
> show collections
复制代码

文档操作

上面的数据库和集合操作是在MongoDB的客户端中进行的,下面的文档操作都是在Robomongo中进行的。

插入文档

  • 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({})
复制代码
{
    "_id" : ObjectId("5e9943661379a112845e4056"),
    "title" : "MongoDB 教程",
    "description" : "MongoDB 是一个 Nosql 数据库",
    "by" : "Andy",
    "url" : "https://www.mongodb.com/",
    "tags" : [ 
        "mongodb", 
        "database", 
        "NoSQL"
    ],
    "likes" : 100.0
}
复制代码

更新文档

  • MongoDB通过collection对象的update()来更新集合中的文档,语法如下;
db.collection.update(
   ,
   ,
   {
     multi: 
   }
)
# query:修改的查询条件,类似于SQL中的WHERE部分
# update:更新属性的操作符,类似与SQL中的SET部分
# multi:设置为true时会更新所有符合条件的文档,默认为false只更新找到的第一条
复制代码
  • 将title为MongoDB 教程的所有文档的title修改为MongoDB;
db.article.update({'title':'MongoDB 教程'},{$set:{'title':'MongoDB'}},{multi:true})
复制代码
  • 除了update()方法以外,save()方法可以用来替换已有文档,语法如下;
db.collection.save(document)
复制代码
  • 这次我们将ObjectId为5e9943661379a112845e4056的文档的title改为MongoDB 教程;
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
})
复制代码

删除文档

  • MongoDB通过collection对象的remove()方法来删除集合中的文档,语法如下;
db.collection.remove(
   ,
   {
     justOne: 
   }
)
# query:删除的查询条件,类似于SQL中的WHERE部分
# justOne:设置为true只删除一条记录,默认为false删除所有记录
复制代码
  • 删除title为MongoDB 教程的所有文档;
db.article.remove({'title':'MongoDB 教程'})
复制代码

查询文档

  • MongoDB通过collection对象的find()方法来查询文档,语法如下;
db.collection.find(query, projection)
# query:查询条件,类似于SQL中的WHERE部分
# projection:可选,使用投影操作符指定返回的键
复制代码
  • 查询article集合中的所有文档;
db.article.find()
复制代码
/* 1 */
{
    "_id" : ObjectId("5e994dcb1379a112845e4057"),
    "title" : "MongoDB 教程",
    "description" : "MongoDB 是一个 Nosql 数据库",
    "by" : "Andy",
    "url" : "https://www.mongodb.com/",
    "tags" : [ 
        "mongodb", 
        "database", 
        "NoSQL"
    ],
    "likes" : 50.0
}

/* 2 */
{
    "_id" : ObjectId("5e994df51379a112845e4058"),
    "title" : "Elasticsearch 教程",
    "description" : "Elasticsearch 是一个搜索引擎",
    "by" : "Ruby",
    "url" : "https://www.elastic.co/cn/",
    "tags" : [ 
        "elasticearch", 
        "database", 
        "NoSQL"
    ],
    "likes" : 100.0
}

/* 3 */
{
    "_id" : ObjectId("5e994e111379a112845e4059"),
    "title" : "Redis 教程",
    "description" : "Redis 是一个key-value数据库",
    "by" : "Andy",
    "url" : "https://redis.io/",
    "tags" : [ 
        "redis", 
        "database", 
        "NoSQL"
    ],
    "likes" : 150.0
}
复制代码
  • MongoDB中的条件操作符,通过与SQL语句的对比来了解下;

操作 格式 SQL中的类似语句 等于 {:} where title = 'MongoDB 教程' 小于 {:{$lt:}} where likes < 50 小于或等于 {:{$lte:}} where likes <= 50 大于 {:{$gt:}} where likes > 50 大于或等于 {:{$gte:}} where likes >= 50 不等于 {:{$ne:}} where likes != 50

  • 条件查询,查询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 教程"}]})
复制代码

其他操作

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)
复制代码

排序

  • 在MongoDB中使用sort()方法对数据进行排序,sort()方法通过参数来指定排序的字段,并使用1和-1来指定排序方式,1为升序,-1为降序;
db.collection.find().sort({KEY:1})
复制代码
  • 按article集合中文档的likes字段降序排列;
db.article.find().sort({likes:-1})
复制代码

索引

  • 索引通常能够极大的提高查询的效率,如果没有索引,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
    }
]
复制代码

聚合

  • MongoDB中的聚合使用aggregate()方法,类似于SQL中的group by语句,语法如下;
db.collection.aggregate(AGGREGATE_OPERATION)
复制代码
  • 聚合中常用操作符如下;

操作符 描述 $sum 计算总和 $avg 计算平均值 $min 计算最小值 $max 计算最大值

  • 根据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
}
复制代码

正则表达式

  • MongoDB使用$regex操作符来设置匹配字符串的正则表达式,可以用来模糊查询,类似于SQL中的like操作;
  • 例如查询title中包含教程的文档;
db.article.find({title:{$regex:"教程"}})
复制代码
  • 不区分大小写的模糊查询,使用$options操作符;
db.article.find({title:{$regex:"elasticsearch",$options:"$i"}})


作者:MacroZheng
链接:
https://juejin.im/post/5eb4043cf265da7bf5368276

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/3467.html

分享给朋友:

“MongoDB快速入门,掌握这些刚刚好” 的相关文章

一套智能停车场收费管理系统设计方案,拓扑图VISIO格式

大家好,我是薛哥。最近VIP会员群的读者咨询停车场管理系统的规划设计方案,今天分享一个模板素材,主要里面的拓扑图可以编辑的,VISIO格式,建议收藏备用。此套完整的Word方案,VIP会员下载!智能停车场收费管理子系统1、系统概述本次停车场管理系统设计纯车牌识别系统,并可在合适的位置设置中央收费点,...

Vue3,父组件子组件传值,provide(提供)和inject(注入)传值

父组件向子组件传值父子组件传递数据时,通常使用的是props和emit,父向子传递使用props,子向父传递使用emit。子组件接收3种方式// 1、简单接收 props:["title","isShow"], // 2、接收的同时对数据类型进行限制 props:{...

Git 分支管理策略汇总

最近,团队新入职了一些小伙伴,在开发过程中,他们问我 Git 分支是如何管理的,以及应该怎么提交代码?我大概说了一些规则,但仔细想来,好像也并没有形成一个清晰规范的流程。所以查了一些资料,总结出下面这篇文章,一共包含四种常见的分支管理策略,分享给大家。Git flow在这种模式下,主要维护了两类分支...

7 招教你轻松搭建以图搜图系统

作者 | 小龙责编 | 胡巍巍当您听到“以图搜图”时,是否首先想到了百度、Google 等搜索引擎的以图搜图功能呢?事实上,您完全可以搭建一个属于自己的以图搜图系统:自己建立图片库;自己选择一张图片到库中进行搜索,并得到与其相似的若干图片。Milvus 作为一款针对海量特征向量的相似性检索引擎,旨在...

html5+css3做的响应式企业网站前端源码

大家好,今天给大家介绍一款,html5+css3做的响应式企业网站前端源码 (图1)。送给大家哦,获取方式在本文末尾。首页banner幻灯片切换特效(图2)首页布局简约合理(图3)关于我们页面(图4)商品列表(图5)商品详情(图6)服务介绍(图7)新闻列表(图8)联系我们(图9)源码完整,需要的朋友...

JS数组过滤元素的方法

引言JavaScript 作为前端开发的核心技术之一,在现代 Web 开发中扮演着举足轻重的角色。随着 Web 应用越来越复杂,高效处理数据集合的需求日益凸显。本文旨在介绍 JavaScript 中数组过滤的基础知识及其在实际项目中的应用技巧。技术概述定义数组过滤是 JavaScript 提供的一种...