MongoDB集合(Collection)的详细使用说明

server/2024/10/19 8:00:05/

以下是关于MongoDB集合(Collection)的详细使用说明:

1. 集合的概念

  • 集合是MongoDB中存储文档的容器,类似于关系型数据库中的表。它是数据库中的一个逻辑分组,用于组织和管理相关的文档。一个数据库可以包含多个集合,每个集合可以包含零个或多个文档。集合中的文档可以具有不同的结构,即它们可以包含不同的字段和数据类型,但都遵循MongoDB的文档格式规范(BSON格式)。

2. 集合的创建

  • 自动创建
    • 当向一个不存在的集合中插入文档时,MongoDB会自动创建该集合。例如:
      • 首先切换到一个数据库(假设数据库名为mydb):use mydb
      • 然后向一个不存在的集合(假设集合名为mycollection)中插入一条文档:db.mycollection.insert({"name":"John","age":30})
      • 此时,mycollection集合就会被自动创建。
  • 手动创建
    • 也可以使用db.createCollection()方法手动创建集合。语法如下:db.createCollection("collection_name", options)
    • 其中collection_name是要创建的集合名称,options是一个可选的配置对象,用于指定集合的一些属性。例如:
      • 创建一个名为logs的普通集合:db.createCollection("logs")
      • 创建一个固定大小的集合(也称为固定集合或 capped collection),并指定其最大字节数为1024 * 1024(1MB),最大文档数量为1000
        db.createCollection("mycappedcollection", {capped: true,size: 1024 * 1024,max: 1000
        });
        

3. 集合的查询

  • 可以使用show collectionsshow tables命令来查询当前数据库中的所有集合。例如,在切换到mydb数据库后,执行show collections命令,会列出mydb数据库中的所有集合。

4. 集合的重命名

  • 可以使用db.collection.renameCollection("new_name")方法来重命名集合。例如,将mycollection集合重命名为newcollectiondb.mycollection.renameCollection("newcollection")

5. 集合的删除

  • 使用db.collection.drop()方法来删除集合。例如,删除mycollection集合:db.mycollection.drop()

6. 集合的文档操作

  • 插入文档
    • 可以使用db.collection.insert()db.collection.insertOne()(插入单个文档)和db.collection.insertMany()(插入多个文档)方法向集合中插入文档。例如:
      • 插入单个文档到mycollection集合:db.mycollection.insertOne({"name":"Alice","age":25})
      • 插入多个文档到mycollection集合:
        var documents = [{"name":"Bob","age":35},{"name":"Carol","age":40}
        ];
        db.mycollection.insertMany(documents);
        
  • 查询文档
    • 使用db.collection.find()方法来查询集合中的文档。可以添加查询条件来筛选特定的文档。例如:
      • 查询mycollection集合中的所有文档:db.mycollection.find()
      • 查询mycollection集合中age大于30的文档:db.mycollection.find({"age": {$gt: 30}})
      • 可以使用.pretty()方法来格式化输出查询结果,使文档结构更清晰:db.mycollection.find({"age": {$gt: 30}}).pretty()
  • 更新文档
    • 使用db.collection.update()方法来更新集合中的文档。有多种更新方式:
      • 更新符合条件的第一条文档:db.collection.updateOne(query, update)。例如,将mycollection集合中nameBob的文档的age更新为36db.mycollection.updateOne({"name": "Bob"}, {"$set": {"age": 36}})
      • 更新符合条件的所有文档:db.collection.updateMany(query, update)。例如,将mycollection集合中age大于30的文档的age都更新为31db.mycollection.updateMany({"age": {$gt: 30}}, {"$set": {"age": 31}})
  • 删除文档
    • 使用db.collection.remove()方法来删除集合中的文档。有以下几种情况:
      • 删除符合条件的第一条文档:db.collection.remove(query, {justOne: true})。例如,删除mycollection集合中nameBob的文档(只删除第一个匹配的):db.mycollection.remove({"name": "Bob"}, {justOne: true})
      • 删除符合条件的所有文档:db.collection.remove(query)。例如,删除mycollection集合中age大于30的文档:db.mycollection.remove({"name": "Bob"}, {justOne: true})
      • 在MongoDB 2.6及以后版本,还可以使用db.collection.deleteOne()(删除符合条件的第一条文档)和db.collection.deleteMany()(删除符合条件的所有文档)方法,它们提供了更明确的操作语义。例如:
        • 删除mycollection集合中nameBob的文档(只删除第一个匹配的):db.mycollection.deleteOne({"name": "Bob"})
        • 删除mycollection集合中age大于30的文档:db.mycollection.deleteMany({"age": {$gt: 30}})

7. 集合的索引操作

  • 创建索引
    • 使用db.collection.ensureIndex()方法来创建索引。语法为:db.collection.ensureIndex({field: direction}, options)
    • 其中field是要创建索引的字段,direction可以是1(升序)或-1(降序),options是一个可选的配置对象,用于指定索引的一些属性。例如:
      • mycollection集合中基于name字段创建一个升序索引:db.mycollection.ensureIndex({"name": 1})
      • 创建一个唯一索引(确保集合中该字段的值是唯一的):
        db.mycollection.ensureIndex({"email": 1}, {unique: true});
        
  • 查询索引
    • 使用db.collection.getIndexes()方法来查询集合中的所有索引。例如:db.mycollection.getIndexes()会返回mycollection集合中所有索引的信息,包括索引名称、基于的字段、排序方向等。
  • 删除索引
    • 使用db.collection.dropIndex()方法来删除集合中的指定索引。例如:db.mycollection.dropIndex("name_1")会删除mycollection集合中基于name字段创建的名为name_1的索引。
    • 使用db.collection.dropIndexes()方法来删除集合中的所有索引。例如:db.mycollection.dropIndexes()会删除mycollection所有的索引。

8. 集合的统计信息

  • 使用db.collection.stats()方法来获取集合的统计信息,包括集合中的文档数量、平均文档大小、存储大小、索引数量、索引大小等。例如:db.mycollection.stats()会返回mycollection集合的统计信息。

http://www.ppmy.cn/server/132988.html

相关文章

python程序设计员—练习笔记

目录 基础处理 字符串列表字典运算符正则表达式re库requestsBeautiful Soupjieba库分词模式基于TF-IDF算法的关键词提取 基于TextRank算法的关键词提取pandas 打开有多个表的.xlsx文件 基础处理 字符串 str_ str_.lower()lower()函数:将字符中的大写字母转换成小…

网络通信与并发编程(二)基于tcp的套接字、基于udp的套接字、粘包现象

基于tcp的套接字 文章目录 基于tcp的套接字一、套接字的工作流程二、基于tcp的套接字通信三、基于udp的套接字通信四、粘包现象 一、套接字的工作流程 Socket是应用层与TCP/IP协议族通信的中间软件抽象层,它是一组接口。在设计模式中,Socket其实就是一个…

重塑企业数字化未来:物联网与微服务架构的战略性深度融合

从物联网到微服务架构的战略价值解读 随着全球数字化转型的不断加速,企业需要重新审视其技术基础架构,以适应日益复杂的业务需求和市场变化。物联网(IoT)作为核心技术,已广泛应用于制造、农业、交通、医疗等各个行业&…

人工智能与生活:探索科技未来的无限可能性

随着科技的不断进步,人工智能已经成为了我们日常生活中不可或缺的一部分。从智能手机到智能家居,从自动驾驶汽车到医疗诊断,人工智能已经渗透到了我们的方方面面。在这篇文章中,我们将从不同的角度探讨人工智能与生活的联系&#…

uniapp 微信小程序分包操作

1. 在项目根目录创建一个新的目录,名称为分包名称 2. 打开manifest.json,选择源码视图,加入以下代码 "optimization" : {"subPackages" : true } 3. 在pages.json中,pages后面添加分包代码 "subPackag…

Java - 使用AOP+SpEL基于DB中的用户ID自动补全用户姓名

Java - 使用AOPSpEL基于DB中的用户ID自动补全用户姓名 文章目录 Java - 使用AOPSpEL基于DB中的用户ID自动补全用户姓名一、引言二、环境三、基本思路四、实现过程1. 确定切入点;2. 基于自定义注解,注册切入点;3. 在实体类上标记依赖关系&…

计算机毕业设计 | SpringBoot大型旅游网站 旅行后台管理系统(附源码)

1, 概述 1.1 项目背景 随着互联网技术的快速发展和普及,旅游行业逐渐转向线上,越来越多的游客选择在线预订旅游产品。传统的线下旅行社模式已不能满足市场需求,因此,开发一个高效、便捷的旅游网站成为行业的迫切需求…

查缺补漏----三次握手与四次挥手

注意事项: ① 如果是和FTP服务器建立连接,那么要建立两个TCP连接。一个是控制连接一个是数据连接。 ② SYN报文段不能携带数据。三次握手的最后一个报文段可以捎带数据,但是如果不携带数据,那么就不消耗序号。 ③ 在断开连接过程中…