MongoDB的索引与聚合

一、实验目的

  1. 理解索引的概念及其在MongoDB中的重要性和作用。

  2. 学习如何选择适合建立索引的字段。

  3. 掌握如何创建、删除索引以及如何强制使用索引。

  4. 熟悉MongoDB的聚合框架和MapReduce工具,以及简单聚合命令的使用。

二、实验环境准备

  1. JAVA环境准备:确保Java Development Kit (JDK) 已安装并配置好环境变量。

  2. Hadoop环境准备:安装并配置Hadoop环境,确保Hadoop的各个组件可以在伪分布式模式下运行。

三、实验教材参考

《大数据存储》,谭旭,人民邮电出版社,2022,ISBN 978-7-115-59414-3。

四、实验内容与步骤

1、索引操作

  1. 创建文档并插入数据

    db.createCollection("studata")
    db.studata.insert({
    name:"Alice",
    age:22,
    score:85,
    class:"Physics"
    })

db.studata.insert([
  { name: "Alice", age: 22, score: 85, class: "Physics" },
{ name: "Bob", age: 21, score: 78, class: "Chemistry" },
{ name: "Charlie", age: 23, score: 92, class: "Physics" },
{ name: "David", age: 20, score: 65, class: "Mathematics" }
]);
  1. 创建单字段索引

db.studata.createIndex({age:1})

  1. 创建复合索引

db.studata.createIndex({ class: 1, score: -1 });

  1. 创建文本索引

db.studata.createIndex({ name: "text" });

  1. 查看查询计划并评估单字段索引效果

db.studata.find({ age: 22 }).explain("executionStats");

  1. 查看查询计划并评估复合索引效果

db.studata.find({ class: "Physics", score: { $gt: 80 } }).explain("executionStats");

  1. 查看查询计划并评估文本索引效果

db.studata.find({ $text: { $search: "Alice" } }).explain("executionStats");

  1. 删除索引

删除单字段索引

db.studata.dropIndex({ age: 1 });

删除复合索引

db.studata.dropIndex({ class: 1, score: -1 });

2、聚合工具

  1. 统计文档数量

db.studata.aggregate([

{ $match: { class: "Physics" } },

{ $group: { _id: null, total_students: { $sum: 1 } } }

]);

  1. 获取字段唯一值

db.studata.distinct("class");

  1. 分组统计

db.studata.aggregate([

{ $group: {

_id: "$class",

total_students: { $sum: 1 },

average_score: { avg: "score" }

} }

]);

  1. 排序和限制

按分数降序排列,取前5名

db.studata.aggregate([

{ $sort: { score: -1 } },

{ $limit: 5 }

]);

  1. 使用MapReduce处理复杂的聚合任务

db.studata.mapReduce(

function() { emit(this.class, this.score); },

function(key, values) { return Array.sum(values); },

{

out: "class_total_scores"

}

);

查看 MapReduce 结果

db.class_total_scores.find();

相关推荐
我们的五年8 分钟前
MySQL存储引擎:选择与应用
数据库·mysql
DC_BLOG32 分钟前
Linux-GlusterFS进阶分布式卷
linux·运维·服务器·分布式
带娃的IT创业者41 分钟前
《Python实战进阶》专栏 No.3:Django 项目结构解析与入门DEMO
数据库·python·django
人间打气筒(Ada)1 小时前
MySQL优化
数据库·mysql
小蒜学长2 小时前
医疗报销系统的设计与实现(代码+数据库+LW)
数据库·spring boot·学习·oracle·课程设计
终端行者2 小时前
kubernetes1.28部署mysql5.7主从同步,使用Nfs制作持久卷存储,适用于centos7/9操作系统,
数据库·容器·kubernetes
羊小猪~~2 小时前
MYSQL学习笔记(九):MYSQL表的“增删改查”
数据库·笔记·后端·sql·学习·mysql·考研
我们的五年2 小时前
MySQL 架构
数据库·mysql·开源
点点滴滴的记录2 小时前
分布式之Raft算法
分布式
橘猫云计算机设计2 小时前
基于SSM的《计算机网络》题库管理系统(源码+lw+部署文档+讲解),源码可白嫖!
java·数据库·spring boot·后端·python·计算机网络·毕设