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()
相关推荐
欧先生^_^4 小时前
Linux内核可配置的参数
linux·服务器·数据库
问道飞鱼4 小时前
【数据库知识】Mysql进阶-高可用MHA(Master High Availability)方案
数据库·mysql·adb·高可用·mha
tiging4 小时前
centos7.x下,使用宝塔进行主从复制的原理和实践
数据库·mysql·adb·主从复制
wangcheng86995 小时前
Oracle常用函数-日期时间类型
数据库·sql·oracle
zizisuo5 小时前
面试篇:Spring Security
网络·数据库·安全
一只fish5 小时前
MySQL 8.0 OCP 1Z0-908 题目解析(2)
数据库·mysql
StarRocks_labs5 小时前
从InfluxDB到StarRocks:Grab实现Spark监控平台10倍性能提升
大数据·数据库·starrocks·分布式·spark·iris·物化视图
搞不懂语言的程序员5 小时前
Redis的Pipeline和Lua脚本适用场景是什么?使用时需要注意什么?
数据库·redis·lua
王RuaRua5 小时前
[数据结构]5. 栈-Stack
linux·数据结构·数据库·链表
Lw老王要学习7 小时前
Linux数据库篇、第一章_02_MySQL的使用增删改查
linux·运维·数据库·mysql·云计算·it