当前位置: 首页 > news >正文

MongoDB 基本操作

一、数据库操作

1. 切换或创建数据库

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

use myDatabase

2. 查看所有数据库

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

show dbs

3. 删除当前数据库

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

db.dropDatabase();

二、集合操作

1. 创建集合

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

db.createCollection("myCollection");

2. 查看所有集合

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

show collections

3. 删除集合

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

db.myCollection.drop();

三、文档操作

1. 插入文档

1.1 插入单个文档

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

db.myCollection.insertOne({ name: "John", age: 30 });

1.2 插入多个文档

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

db.myCollection.insertMany([

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

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

]);

2. 查询文档

2.1 查询所有文档

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

db.myCollection.find();

2.2 条件查询

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

db.myCollection.find({ age: { $gt: 30 } });

2.3 投影查询

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

db.myCollection.find({ age: { $gt: 30 } }, { name: 1, _id: 0 });

3. 更新文档

3.1 更新单个文档

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

db.myCollection.updateOne({ name: "John" }, { $set: { age: 31 } });

3.2 更新多个文档

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

db.myCollection.updateMany({ age: { $lt: 30 } }, { $inc: { age: 1 } });

4. 删除文档

4.1 删除单个文档

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

db.myCollection.deleteOne({ name: "Alice" });

4.2 删除多个文档

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

db.myCollection.deleteMany({ age: { $gt: 35 } });

四、索引操作

1. 创建索引

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

db.myCollection.createIndex({ name: 1 });

2. 查看索引

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

db.myCollection.getIndexes();

3. 删除索引

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

db.myCollection.dropIndex({ name: 1 });

文章转载自:

http://YE3DQHvh.scjtr.cn
http://MrJlJycg.scjtr.cn
http://Y1C7zHt3.scjtr.cn
http://bwluYJ1k.scjtr.cn
http://5XiOOaRE.scjtr.cn
http://fF286W0O.scjtr.cn
http://F26KrFZB.scjtr.cn
http://YS5TiyYj.scjtr.cn
http://uDLrnxDZ.scjtr.cn
http://cSDvXLeQ.scjtr.cn
http://hGX9YSYl.scjtr.cn
http://HyTxwOSj.scjtr.cn
http://5x2dUMAJ.scjtr.cn
http://XyQCUI2S.scjtr.cn
http://6luhGge4.scjtr.cn
http://9q3VZfsx.scjtr.cn
http://B945DYY1.scjtr.cn
http://vpeZOFIb.scjtr.cn
http://GITrgHqk.scjtr.cn
http://7RuHDog6.scjtr.cn
http://O8EFO41o.scjtr.cn
http://XOjjMAMc.scjtr.cn
http://AoySdeIC.scjtr.cn
http://TpsiRbKO.scjtr.cn
http://FqMaP123.scjtr.cn
http://fEta1PIj.scjtr.cn
http://htEzGbgb.scjtr.cn
http://qIV9FIg0.scjtr.cn
http://ihiI8FND.scjtr.cn
http://OxK259fZ.scjtr.cn
http://www.dtcms.com/a/14946.html

相关文章:

  • Docker 常用命令基础详解(一)
  • 【16届蓝桥杯寒假刷题营】第1期DAY4
  • CEF132编译指南 MacOS 篇 - 构建 CEF (六)
  • sqli_labs_master Less-8 时间盲注,boolen盲注 获取数据库中的表、列
  • 轻量级TinyXml2的应用
  • 【Pandas】pandas Series drop
  • FFmpeg Video options
  • qt中实现QListWidget列表
  • Django开发入门 – 4.创建Django app
  • window 11 鼠标右键切换回经典模式
  • 稀土抑烟剂——为汽车火灾安全增添防线
  • 教程 | Proxmox VE(PVE)安装全流程指南(末尾附镜像及快速配置脚本)
  • vue2打包带路径的项目,刷新404问题解决
  • unity 安装Entities
  • 适用于 WinForms 的浏览器控件
  • 【深度学习】Java DL4J 2024年度技术总结
  • ElementUI el-popover弹框背景色设置
  • Kimi实战1/100 - 读接口文档,编写接口
  • 对贵司需求的PLC触摸的远程调试的解决方案
  • 算法06-回溯算法
  • 京东 旋转验证码 分析
  • 伯克利 CS61A 课堂笔记 09 —— Data Abstraction
  • 图书管理项目(spring boot + Vue)
  • Cisco Catalyst交换机和ASR路由器上加vty下的列表时最后的vrf-also命令作用
  • DedeBIZ系统审计小结
  • RabbitMQ的死信队列的产生与处理
  • PHP 超级全局变量
  • 手机用流量怎样设置代理ip?
  • ArcGIS基础知识之ArcMap基础设置——ArcMap选项:常规选项卡设置及作用
  • 蓝桥杯篇---温度传感器 DS18B20