• MongoDb-01——Mac上安装MongoDb以及相关的简单命令


    1. 下载、安装

    1.1 官网下载

    1.2 关于安装MongoDB

    1.2.1 官方安装文档

    1.2.2 Mac安装详细步骤(使用brew)

    • 我这里也是参考上面安装步骤,使用 brew 进行安装的,具体请看下面步骤。
      关于 brew ,如果没有安装的,请移步下面的文章:
      mac上安装Homebrew的详细介绍包括解决各种问题以及使用Homebrew安装git、svn等软件.
    • 安装步骤:
      • 更新 brew,随自己,可更新可不更新
        brew update
        
        • 1
      • 创建一个tap仓库
        brew tap mongodb/brew
        
        • 1
        在这里插入图片描述
      • 安装指定版本的 mongodb-community Server,如果不指定版本,默认好像也是安装最新版本
        brew install mongodb-community@7.0
        
        • 1
    • 查看是否安装成功
      • 安装之后,通过下面命令查看是否安装上
        brew list
        
        • 1
        在这里插入图片描述
    • 安装文件说明
      • 除二进制文件外,安装过程还会根据你的Apple硬件在以下指定位置创建以下文件和目录,如下:
        在这里插入图片描述
      • 可以执行以下命令来检查brew将这些文件和目录安装在哪里
        brew --prefix
        
        • 1
        在这里插入图片描述

    2. 启动MongoDB

    2.1 官方说明

    • 直接看官网说明:
      在这里插入图片描述

    2.2 作为macOS服务运行的相关命令

    • 启动服务:
      brew services stop mongodb-community@7.0
      
      • 1
    • 查看MongoDB服务是否正在运行
      brew services list
      
      • 1
      在这里插入图片描述
    • 停止服务:
      brew services stop mongodb-community@7.0
      
      • 1
    • 查看占用的端口
      • 先查看进程ID
        ps -ef | grep mongodb
        
        • 1
        在这里插入图片描述
      • 使用 lsof ,根据进程ID查看端口
        lsof -i | grep 24403 
        
        • 1
        在这里插入图片描述
      • 补:使用 lsof ,根据端口 查 服务和进程
        lsof -i:27017
        
        • 1
        在这里插入图片描述

    2.3 访问

    • 知道端口之后不妨访问试试,当然,访问不通,协议不同,但是可以说明mongodb服务启动了,如下:
      http://127.0.0.1:27017/
      
      • 1
      在这里插入图片描述

    3. 链接并使用mongodb

    3.1 链接mongodb

    • 链接命令:
      mongosh
      
      • 1
      在这里插入图片描述

    3.2 简单使用mongodb

    3.2.1 简单命令

    • 常用简单命令,如下:
      show dbs   #查看所有数据库
      
      db   # 查看当前数据库
      
      db.getName() #查看当前数据库名称
      
      use dbName   # 切换数据库(注意:有这个数据库,则会选中这个数据库,没有则会创建)
      
      db.version()  # 查看mongodb版本
      
      db.stats()   # 查看数据库状态信息
      
      db.getMongo()  #查看数据库的链接地址
      
      db.dropDatabase()  # 删除数据库
      ……
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
      • 9
      • 10
      • 11
      • 12
      • 13
      • 14
      • 15
      • 16
      在这里插入图片描述
    • 关于创建 数据库 和 集合
      use susu_test    # 切换数据库susu_test(注意:有这个数据库,则会选中这个数据库,没有则会创建)
      
      db.createCollection(name, options)    # 创建集合  name:集合名,字符
      db.createCollection('dog')
      
      show collections   # 查看当前数据库所有集合
      
      db.集合名.renameCollection('集合新名')    # 重命名集合
      db.cat.renameCollection('cats')
      
      db.集合名.drop()    # 删除集合
      db.cats.drop()
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
      • 9
      • 10
      • 11
      • 12
      在这里插入图片描述

    3.2.2 简单crud使用(文档命令)

    3.2.2.1 插入数据
    • 插入单条数据
      • 语法:
        db.dog.insert({})
        
        db.dog.insertOne({})
        
        • 1
        • 2
        • 3
      • 例子:
        db.dog.insert({dogNum:'A-1001',dogName:'麦兜',dogAge:3,dogKind:'边牧'})
        
        db.dog.insertOne({dogNum:'A-1002',dogName:'泡泡',dogAge:5,dogKind:'柯基'})
        
        • 1
        • 2
        • 3
    • 插入多条数据
      • 语法:
        db.dog.insert([{},{}])
        
        • 1
      • 例子:
        db.dog.insert([{dogNum:'A-1003',dogName:'大牙',dogAge:2,dogKind:'边牧'},{dogNum:'A-1004',dogName:'闪闪',dogAge:8,dogKind:'秋田'}])
        
        • 1
    • 如图:
      在这里插入图片描述
      在这里插入图片描述
    3.2.2.2 查询数据
    3.2.2.2.1 一般查询
    • 语法如下:
      db.dog.find()   # 1.查询所有
      
      db.集合名.find({key:val})   # 2.指定键值对条件查询
      db.dog.find({dogNum:'A-1005'})
      
      db.集合名.find({key:{$in:[value1,value2]}})    # 3.包含,等价于sql中的in查询
      db.dog.find({dogNum:{$in:['A-1005','A-1006']}})
      
      db.集合名.find({key1:val1},{key2:val2}……)  # 4. 多条件查询 同时满足
      db.dog.find({dogKind:'边牧',dogAge:{$lt:3}})  #品种是边牧,并且年龄小于3的
      db.dog.find({$and:[{dogKind:'边牧'},{dogAge:{$lt:3}}]}) #$and 等价于上条写法
      
      db.dog.find({$or:[{dogKind:'边牧'},{dogAge:{$lt:3}}]}) # $or 满足条件之一即可
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
      • 9
      • 10
      • 11
      • 12
      • 13
    • 效果如下:
      在这里插入图片描述
      在这里插入图片描述
    3.2.2.2.2 模糊查询
    • 语法如下:
      db.集合名.find({key:/val/})   #  1. 模糊查询(包含val的数据),  注意:val 不能用引号
      db.dog.find({dogName:/兜/})
      
      db.集合名.find({ key: /^val/})  # 2.1 查询key中包含val,且以val开头的数据
      db.dog.find({dogName:/^麦/})  # 注意:不加引号
      
      db.dog.find({key:{$regex:'^val'}})  # 2.2 查询key中包含val,且以val开头的数据
      db.dog.find({dogName:{$regex:'^麦'}})  # 注意:加引号
      
      # 同理,查询以XXX结尾的语法类似,两种写法,如下:
      db.dog.find({dogName:/兜$/})
      db.dog.find({dogName:{$regex:'兜$'}})
      
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
      • 9
      • 10
      • 11
      • 12
      • 13
    • 效果如下:
      在这里插入图片描述
      在这里插入图片描述
    3.2.2.2.3 排序查询
    • 语法:
      db.集合名.find({key:val}).sort({key:1})  # 1 升序,-1 将序
      
      db.dog.find({dogKind:'边牧'}).sort({dogAge:-1}) # 按年龄将序
      
      • 1
      • 2
      • 3
      在这里插入图片描述
    3.2.2.2.4 分页查询
    • 语法:
      db.集合名.find({key:val}).limit(num).skip(start)  # num:表示pageSzie , start:表示起始索引,默认为0
      
      db.dog.find({dogKind:'边牧'}).limit(2).skip(1)
      
      • 1
      • 2
      • 3
    • 如下:
      在这里插入图片描述
    3.2.2.3 修改数据
    • 语法如下:
      db.dog.updateOne({key:val},[{$set:{key1:val1,key2:val2}}])
      
      db.dog.updateOne({dogName:'麦兜'},[{$set:{dogKind:'边境牧羊犬'}}])
      db.dog.updateOne({dogName:'麦兜'},[{$set:{dogKind:'边牧犬',dogAge:4}}])
      db.dog.updateOne({dogName:'麦兜'},{$set:{dogKind:'边牧犬22',dogAge:3}})  # []可以去掉
      
      • 1
      • 2
      • 3
      • 4
      • 5
    3.2.2.4 删除数据
    • 根据指定的键值对条件:
      db.集合.deleteOne({key:val})   # 1.1 删除单条数据,最多删除一个匹配指定筛选器的文档,即使多个文档可能匹配指定筛选器。
      db.dog.findOneAndDelete({dogKind:'秋田'}) # 1.2 删除单条数据,即便满足的有多条,删除之后,返回删除的数据
      
      db.集合.deleteMany({key:val})  # 删除多条数据,删除与指定筛选器匹配的所有文档。
      
      db.dog.remove({dogKind:'边牧'});  # remove() 删除满足条件的数据(可多条) ,但提示方法已被弃用
      
      db.集合.deleteMany({})   # 删除所有数据(如果给条件删除满足条件的数据,如果不给条件,删除所有的数据)
      db.dog.deleteMany({dogNum:{$in:['A-1005','A-1006']}})  # 删除满足条件的数据
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
      • 9
    3.2.2.5 更多操作参考
    3.2.2.5.1 更多语法及例子
    3.2.2.5.2 操作符等其他更多文档

    4. navicat链接

    • 服务只要起着,直接连就行
      在这里插入图片描述
    • 连上之后查看数据:
      • 可以使用命令查询:
        在这里插入图片描述
      • 也可以使用navicat自带的图形化查询
        在这里插入图片描述
  • 相关阅读:
    H5 简约四色新科技风引导页源码
    2.MySQL 基础知识
    明明加了唯一索引,为什么还是产生了重复数据?
    分享一个实用的MySQL一键巡检脚本
    中石化、中石油接口文档源码分享
    数电学习(八、九、可编程逻辑器件)
    【C++】unordered_set、unordered_map的介绍及使用
    记一次黑入盗号网站
    MyBatis-Plus(三、增删改查)
    扫地僧站群·静态养站王:自动万站智能LOGO功能说明
  • 原文地址:https://blog.csdn.net/suixinfeixiangfei/article/details/132590099