热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

MongoDB命令行操作指南

本文档详细介绍了如何在MongoDB命令行中执行基本操作,包括数据库的选择与创建、文档的插入与查询、文档的更新与删除等。同时,还涵盖了条件查询、统计、模糊查询等高级功能。
### 1. 数据库的选择与创建
在MongoDB中,选择或创建数据库非常简单,使用`use`命令即可。如果指定的数据库不存在,MongoDB会自动创建它。
```shell
use spitdb
```
上述命令会选择或创建名为`spitdb`的数据库。

### 2. 文档的插入与查询
#### 2.1 插入文档
向集合中插入文档使用`insert`命令。例如,向`spit`集合中插入几条测试数据:
```shell
db.spit.insert({content: '听说十次方课程很给力呀', userid: '1011', nickname: '小雅', visits: NumberInt(902)})
```
每条文档都会自动生成一个名为`_id`的字段,作为文档的唯一标识。如果不指定`_id`,MongoDB会自动为其分配一个`ObjectId`类型的值。

#### 2.2 查询文档
查询集合中的所有文档使用`find`命令。例如,查询`spit`集合中的所有文档:
```shell
db.spit.find()
```
若要根据特定条件查询文档,可以在`find`方法中传入条件参数。例如,查询`userid`为`1013`的文档:
```shell
db.spit.find({userid: '1013'})
```
如果只需返回符合条件的第一条文档,可以使用`findOne`命令:
```shell
db.spit.findOne({userid: '1013'})
```
还可以通过`limit`方法限制返回的文档数量:
```shell
db.spit.find().limit(3)
```

### 3. 文档的更新与删除
#### 3.1 更新文档
更新文档使用`update`命令。例如,更新`_id`为`1`的文档,将其`visits`字段设置为`1000`:
```shell
db.spit.update({_id: '1'}, {$set: {visits: NumberInt(1000)}})
```
注意,使用`$set`操作符可以确保只更新指定的字段,而不影响其他字段。

#### 3.2 删除文档
删除文档使用`remove`命令。例如,删除`visits`为`1000`的文档:
```shell
db.spit.remove({visits: 1000})
```
要删除集合中的所有文档,可以使用空条件:
```shell
db.spit.remove({})
```
**注意**:此操作会删除集合中的所有文档,请谨慎使用。

### 4. 记录统计
统计集合中的记录数使用`count`方法。例如,统计`spit`集合中的记录总数:
```shell
db.spit.count()
```
如果要按条件统计,可以在`count`方法中传入条件参数。例如,统计`userid`为`1013`的记录数:
```shell
db.spit.count({userid: '1013'})
```

### 5. 高级查询
#### 5.1 模糊查询
MongoDB支持使用正则表达式进行模糊查询。例如,查询`content`中包含“流量”的文档:
```shell
db.spit.find({content: /流量/})
```
查询`content`以“加班”开头的文档:
```shell
db.spit.find({content: /^加班/})
```

#### 5.2 条件查询
MongoDB提供了多种条件查询操作符,如`$gt`(大于)、`$lt`(小于)、`$gte`(大于等于)、`$lte`(小于等于)和`$ne`(不等于)。例如,查询`visits`大于`1000`的文档:
```shell
db.spit.find({visits: {$gt: 1000}})
```

#### 5.3 包含与不包含查询
使用`$in`操作符可以查询包含特定值的文档。例如,查询`userid`为`1013`或`1014`的文档:
```shell
db.spit.find({userid: {$in: ['1013', '1014']}})
```
使用`$nin`操作符可以查询不包含特定值的文档。例如,查询`userid`不为`1013`或`1014`的文档:
```shell
db.spit.find({userid: {$nin: ['1013', '1014']}})
```

#### 5.4 条件连接
如果需要查询同时满足多个条件的文档,可以使用`$and`操作符。例如,查询`visits`大于等于`1000`且小于`2000`的文档:
```shell
db.spit.find({$and: [{visits: {$gte: 1000}}, {visits: {$lt: 2000}}]})
```
如果需要查询满足任一条件的文档,可以使用`$or`操作符。例如,查询`userid`为`1013`或`visits`小于`2000`的文档:
```shell
db.spit.find({$or: [{userid: '1013'}, {visits: {$lt: 2000}}]})
```

#### 5.5 列值增长
使用`$inc`操作符可以实现对某个字段值的递增或递减。例如,将`_id`为`1`的文档的`visits`字段值增加`100`:
```shell
db.spit.update({_id: '1'}, {$inc: {visits: 100}})
```

推荐阅读
  • 本文详细探讨了 Java 中 Daemon 线程的特点及其应用场景,并深入分析了 Random 类的源代码,帮助开发者更好地理解和使用这些核心组件。 ... [详细]
  • 本文档详细介绍了服务器与应用系统迁移的策略与实施步骤。迁移不仅涉及数据的转移,还包括环境配置、应用兼容性测试等多个方面,旨在确保迁移过程的顺利进行及迁移后的系统稳定运行。 ... [详细]
  • 在使用 SQL 语句从数据库中提取数据并尝试将其转换为其他数据类型时,可能会遇到 'java.math.BigDecimal cannot be cast to java.lang.Integer' 错误。本文将详细解释这一错误的原因,并提供有效的解决方案。 ... [详细]
  • 本文介绍了一种方法,用于创建一个包含中文数据的 Employees 表,并确保在 SQL Server 中能够正确显示和处理中文字符。 ... [详细]
  • 开发笔记:每篇半小时1天入门MongoDB——3.MongoDB可视化及shell详解
    开发笔记:每篇半小时1天入门MongoDB——3.MongoDB可视化及shell详解 ... [详细]
  • ThinkPHP 文件缓存组件详解与应用
    本文深入探讨了ThinkPHP框架中的文件缓存类实现,提供了详细的代码示例和使用说明,旨在帮助开发者更好地理解和利用这一功能来优化应用程序性能。 ... [详细]
  • SonarQube配置与使用指南
    本文档详细介绍了SonarQube的配置方法及使用流程,包括环境准备、样本分析、数据库配置、项目属性文件解析以及插件安装等内容,适用于具有Linux基础操作能力的用户。 ... [详细]
  • 深入理解Hibernate延迟加载机制
    本文探讨了Hibernate框架中的延迟加载(懒加载)特性,分析其对程序性能的影响及实现原理,同时提供了具体的代码示例来说明如何配置和使用延迟加载。 ... [详细]
  • 深入浅出:Java面向对象编程
    本文详细介绍了Java语言的核心特性——面向对象编程。探讨了Java的基本概念、平台无关性、丰富的内置类库及安全性,同时深入解析了类加载器、垃圾回收机制以及基本数据类型和其包装类。 ... [详细]
  • Java中String对象的多种创建与使用方法详解
    本文详细介绍了Java中创建String对象的几种常见方式,包括直接使用双引号、通过new关键字、以及不同创建方式组合使用时的特点和注意事项。同时,文章还探讨了这些创建方式对内存的影响,特别是它们如何影响常量池和堆空间。 ... [详细]
  • 解决Linux Ubuntu下Ping IP正常但无法Ping域名的问题
    本文介绍了在Linux Ubuntu系统中遇到的一种常见问题——能够Ping通IP地址,但无法Ping通域名,并提供了有效的解决方案。 ... [详细]
  • 本文详细介绍了 KALDI 中 CUDA 矩阵库的使用与功能,包括其如何提高计算效率以及在不同环境下的适应性。 ... [详细]
  • 本文探讨了在Java中处理JSON数据的各种方法,包括APIJSON的使用案例,以及如何通过不同的工具和库实现JSON与Java对象之间的高效转换。 ... [详细]
  • 根据用户输入的名字随机推荐用户名
    Scala根据用户输入的名字随机推荐用户名不是copy就能用的,要理解逻辑逻辑根据用户名字判断,如果名字长度是0,或者纯数字的名字& ... [详细]
  • django项目中使用手机号登录
    本文使用聚合数据的短信接口,需要先获取到申请接口的appkey和模板id项目目录下创建ubtils文件夹,定义返回随机验证码和调取短信接口的函数function.py文件se ... [详细]
author-avatar
Elaine_Fox
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有