MongoDB 基本操作

一、数据库操作

1. 切换或创建数据库

使用`use`命令切换到指定数据库,若该数据库不存在,在首次插入数据时会自动创建。

bash 复制代码
use myDatabase

2. 查看所有数据库

使用`show dbs`命令查看 MongoDB 实例中的所有数据库。

bash 复制代码
show dbs

3. 删除当前数据库

使用`db.dropDatabase()`命令删除当前使用的数据库。

bash 复制代码
db.dropDatabase();

二、集合操作

1. 创建集合

使用`db.createCollection()`方法创建集合,也可以不手动创建,插入文档时若集合不存在会自动创建。

bash 复制代码
db.createCollection("myCollection");

2. 查看所有集合

使用`show collections`命令查看当前数据库中的所有集合。

bash 复制代码
show collections

3. 删除集合

使用`db.collection.drop()`方法删除指定集合。

bash 复制代码
db.myCollection.drop();

三、文档操作

1. 插入文档

1.1 插入单个文档

使用`db.collection.insertOne()`方法插入单个文档。

bash 复制代码
db.myCollection.insertOne({ name: "John", age: 30 });

1.2 插入多个文档

使用`db.collection.insertMany()`方法插入多个文档。

bash 复制代码
db.myCollection.insertMany([

  { name: "Alice", age: 25 },

  { name: "Bob", age: 35 },

]);

2. 查询文档

2.1 查询所有文档

使用`db.collection.find()`方法查询集合中的所有文档。

bash 复制代码
db.myCollection.find();

2.2 条件查询

在`find()`方法中传入查询条件对象,可根据条件查询文档。查询`age`大于 30 的文档

bash 复制代码
db.myCollection.find({ age: { $gt: 30 } });

2.3 投影查询

可指定返回的字段,第二个参数传入投影对象,值为 1 表示返回该字段,值为 0 表示不返回。

bash 复制代码
db.myCollection.find({ age: { $gt: 30 } }, { name: 1, _id: 0 });

3. 更新文档

3.1 更新单个文档

使用`db.collection.updateOne()`方法更新符合条件的第一个文档。`$set`是更新操作符,用于设置字段的值。

bash 复制代码
db.myCollection.updateOne({ name: "John" }, { $set: { age: 31 } });

3.2 更新多个文档

使用`db.collection.updateMany()`方法更新所有符合条件的文档。将`age`小于 30 的所有文档的`age`字段加 1,`$inc`是更新操作符,用于增加字段的值。

bash 复制代码
db.myCollection.updateMany({ age: { $lt: 30 } }, { $inc: { age: 1 } });

4. 删除文档

4.1 删除单个文档

使用`db.collection.deleteOne()`方法删除符合条件的第一个文档。

bash 复制代码
db.myCollection.deleteOne({ name: "Alice" });

4.2 删除多个文档

使用`db.collection.deleteMany()`方法删除所有符合条件的文档。

bash 复制代码
db.myCollection.deleteMany({ age: { $gt: 35 } });

四、索引操作

1. 创建索引

使用`db.collection.createIndex()`方法为指定字段创建索引。为`name`字段创建升序索引,`1`表示升序,`-1`表示降序。

bash 复制代码
db.myCollection.createIndex({ name: 1 });

2. 查看索引

使用`db.collection.getIndexes()`方法查看集合的所有索引。

bash 复制代码
db.myCollection.getIndexes();

3. 删除索引

使用`db.collection.dropIndex()`方法删除指定索引。

bash 复制代码
db.myCollection.dropIndex({ name: 1 });
相关推荐
计算机毕设定制辅导-无忧学长3 小时前
西门子 PLC 与 Modbus 集成:S7-1500 RTU/TCP 配置指南(一)
服务器·数据库·tcp/ip
程序员柳4 小时前
基于微信小程序的校园二手交易平台、微信小程序校园二手商城源代码+数据库+使用说明,layui+微信小程序+Spring Boot
数据库·微信小程序·layui
梦在深巷、4 小时前
MySQL/MariaDB数据库主从复制之基于二进制日志的方式
linux·数据库·mysql·mariadb
IT乌鸦坐飞机4 小时前
ansible部署数据库服务随机启动并创建用户和设置用户有完全权限
数据库·ansible·centos7
IT_10244 小时前
Spring Boot项目开发实战销售管理系统——数据库设计!
java·开发语言·数据库·spring boot·后端·oracle
祁思妙想5 小时前
八股学习(三)---MySQL
数据库·学习·mysql
惊骇世俗王某人6 小时前
1.MySQL之如何定位慢查询
数据库·mysql
秦歌6666 小时前
向量数据库-Milvus快速入门
数据库·milvus
Edingbrugh.南空8 小时前
Flink SQLServer CDC 环境配置与验证
数据库·sqlserver·flink
码不停蹄的玄黓8 小时前
MySQL分布式ID冲突详解:场景、原因与解决方案
数据库·分布式·mysql·id冲突