MongoDB常用操作

MongoDB 是一个基于分布式文件存储的开源数据库系统,它使用 JSON 类似的文档结构来存储数据。下面是一些 MongoDB 中常用的命令和操作:

连接到 MongoDB

  • 使用 mongosh 命令行工具连接到本地 MongoDB 服务器:

    shell 复制代码
    mongosh  
  • 连接到远程 MongoDB 服务器:

    shell 复制代码
    mongosh  <hostname>:<port>/<database> -u <username> -p <password>

数据库操作

  • 显示所有数据库:

    javascript 复制代码
    show dbs
  • 切换/选择数据库:

    javascript 复制代码
    use <database_name>
  • 创建或切换到新数据库(如果不存在则创建):

    javascript 复制代码
    use new_database

集合操作

  • 显示当前数据库中所有的集合:

    javascript 复制代码
    show collections
  • 创建集合(通常不需要手动创建,插入文档时会自动创建):

    javascript 复制代码
    db.createCollection("collection_name")
  • 删除集合:

    javascript 复制代码
    db.collection_name.drop()

文档操作

  • 插入单个文档:

    javascript 复制代码
    db.collection_name.insertOne({ key: value, ... })
  • 插入多个文档:

    javascript 复制代码
    db.collection_name.insertMany([{ key1: value1, ... }, { key2: value2, ... }])
  • 查询文档:

    javascript 复制代码
    db.collection_name.find({ key: value, ... }).pretty() // pretty() 使输出更易读
  • 更新单个文档:

    javascript 复制代码
    db.collection_name.updateOne({ key: value, ... }, { $set: { key: newValue, ... }})
  • 更新多个文档:

    javascript 复制代码
    db.collection_name.updateMany({ key: value, ... }, { $set: { key: newValue, ... }})
  • 删除单个文档:

    javascript 复制代码
    db.collection_name.deleteOne({ key: value, ... })
  • 删除多个文档:

    javascript 复制代码
    db.collection_name.deleteMany({ key: value, ... })

其他常用命令

  • 查看帮助信息:

    javascript 复制代码
    help
  • 获取当前使用的数据库名称:

    javascript 复制代码
    db.getName()
  • 退出 MongoDB shell:

    javascript 复制代码
    exit

拓展命令

  • 分页
javascript 复制代码
var pageSize = 10;  // 每页显示的记录数
var page = 2;       // 页码,从1开始
var skipCount = (page - 1) * pageSize;  // 计算需要跳过的记录数

db.users.find().skip(skipCount).limit(pageSize).pretty();
  • 查看索引
javascript 复制代码
db.users.getIndexes()
  • 查找users集合里面uid字段重复的数据
javascript 复制代码
db.users.aggregate([
  {
    $group: {
      _id: "$uid",
      count: { $sum: 1 }
    }
  },
  {
    $match: {
      count: { $gt: 1 }
    }
  }
])
  • 查找所有uid有值的数量
javascript 复制代码
db.users.countDocuments({ uid: { $exists: true, $ne: null } })
  • uid去重后的数据
javascript 复制代码
db.users.distinct("uid")
相关推荐
zxrhhm3 小时前
MySQL 8.4 LTS 数据库巡检脚本
数据库·mysql
AI木马人3 小时前
9.【AI任务队列实战】如何在高并发下保证系统不崩?(Redis + Celery完整方案)
数据库·人工智能·redis·神经网络·缓存
2401_883600253 小时前
golang如何理解weak pointer弱引用_golang weak pointer弱引用总结
jvm·数据库·python
aLTttY3 小时前
【Redis实战】分布式锁的N种实现方案对比与避坑指南
数据库·redis·分布式
2301_773553623 小时前
mysql如何评估SQL语句的索引开销_mysql性能追踪与分析
jvm·数据库·python
pele5 小时前
PHP源码运行受主板供电影响吗_供电相数重要性说明【技巧】
jvm·数据库·python
sinat_383437365 小时前
CSS如何实现元素悬浮在页面底部_利用fixed定位与底部间距
jvm·数据库·python
gmaajt5 小时前
mysql如何备份与恢复函数定义_mysql mysqldump导出存储对象
jvm·数据库·python
阿丰资源5 小时前
基于SpringBoot的在线视频教育平台的设计与实现(附源码+数据库+文档,一键运行)
数据库·spring boot·后端
qq_460978405 小时前
Python爬虫怎么模拟手机端抓取_设置手机型号User-Agent字符串
jvm·数据库·python