MongoDB常用命令

数据库操作

显示所有数据库

复制代码
show dbs

切换/创建数据库 (如果数据库不存在则创建)

复制代码
use <database_name>

删除当前数据库

复制代码
db.dropDatabase()

查看当前数据库

复制代码
db

查看数据库状态

复制代码
db.stats()

集合操作

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

复制代码
show collections

创建集合

复制代码
db.createCollection("<collection_name>")

删除集合

复制代码
db.<collection_name>.drop()

重命名集合

复制代码
db.集合名.renameCollection("新集合名")

文档操作

插入单个文档( 属于 MongoDB 3.2+ 引入的现代 CRUD API**)**

复制代码
db.<collection_name>.insertOne({key1: value1, key2: value2, ...})

插入多个文档( 属于 MongoDB 3.2+ 引入的现代 CRUD API**)**

复制代码
db.<collection_name>.insertMany([
  {key1: value1, key2: value2},
  {key1: value3, key2: value4},
  ...
])

插入 单个文档多个文档( MongoDB 早期版本的通用插入方法)

复制代码
// 插入单个文档
db.users.insert({ name: "Alice", age: 25 });

// 插入多个文档
db.users.insert([
  { name: "Bob", age: 30 },
  { name: "Charlie", age: 28 }
]);

新项目优先使用 insertOne()insertMany():语法更清晰,返回值更易用。符合现代 MongoDB 的 API 设计规范。

避免混用 insert():除非需要兼容旧版本或特定场景。

查询所有文档

复制代码
db.<collection_name>.find()

排序查询结果

复制代码
db.<collection_name>.find().sort({key: 1})  // 1为升序,-1为降序

条件查询

复制代码
db.<collection_name>.find({key: value})

查询第一条记录

复制代码
db.<collection_name>.findOne()

限制返回数量

复制代码
db.<collection_name>.find().limit(5)

更新单个文档

复制代码
db.<collection_name>.updateOne(
  {filter_key: filter_value},  // 过滤条件
  {$set: {key1: new_value1, key2: new_value2}}  // 更新操作
)

更新多个文档

复制代码
db.<collection_name>.updateMany(
  {filter_key: filter_value},
  {$set: {key1: new_value1, key2: new_value2}}
)

替换文档

复制代码
db.<collection_name>.replaceOne(
  {filter_key: filter_value},
  {new_document}
)

删除单个文档

复制代码
db.<collection_name>.deleteOne({key: value})

删除多个文档

复制代码
db.<collection_name>.deleteMany({key: value})

实用命令

获取命令帮助

复制代码
db.help()

获取集合方法帮助

复制代码
db.<collection_name>.help()

查看当前数据库

复制代码
db.getName()

查看MongoDB版本

复制代码
db.version()
相关推荐
砚边数影2 小时前
数据可视化入门:Matplotlib 基础语法与折线图绘制
数据库·信息可视化·matplotlib·数据可视化·kingbase·数据库平替用金仓·金仓数据库
orange_tt2 小时前
Djiango配置Celery
数据库·sqlite
云小逸3 小时前
【nmap源码学习】 Nmap网络扫描工具深度解析:从基础参数到核心扫描逻辑
网络·数据库·学习
肉包_5113 小时前
两个数据库互锁,用全局变量互锁会偶发软件卡死
开发语言·数据库·c++
霖霖总总3 小时前
[小技巧64]深入解析 MySQL InnoDB 的 Checkpoint 机制:原理、类型与调优
数据库·mysql
此刻你4 小时前
常用的 SQL 语句
数据库·sql·oracle
それども4 小时前
分库分表的事务问题 - 怎么实现事务
java·数据库·mysql
·云扬·5 小时前
MySQL Binlog 配置指南与核心作用解析
数据库·mysql·adb
天空属于哈夫克35 小时前
Java 版:利用外部群 API 实现自动“技术开课”倒计时提醒
数据库·python·mysql
eWidget5 小时前
随机森林原理:集成学习思想 —— Java 实现多棵决策树投票机制
java·数据库·随机森林·集成学习·金仓数据库