【MongoDB】索引 - 数组字段的多键索引

数组字段创建索引时,MongoDB会为数组中的每个元素创建索引键(多键索引),多键索引支持数组字段的高效查询。

一、准备工作

这里准备一些数据

bash 复制代码
db.shop.insertMany([
    {_id: 1, name: "水果店1", fruits: ["apple", "orange"]},
    {_id: 2, name: "水果店2", fruits: ["banana", "apple"]},
    {_id: 3, name: "水果店3", fruits: ["apple", "banana", "orange"]}
]);

二、创建索引

1、创建索引

bash 复制代码
db.shop.createIndex({ fruits: 1 });

上面创建了fruits字段的复合索引,其中1代表的是正序排序,-1代表的是倒序排序

2、查询索引

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

结果如下:

可以看到多了一个名称为fruits_1的索引

三、示例1:匹配一个

1、执行查询

bash 复制代码
db.shop.find({ fruits: 'banana' });

结果如下:

2、执行过程

bash 复制代码
db.shop.find({ fruits: 'banana' }).explain();

结果如下:

可以看到查询过程中会使用到索引名称为fruits _1的索引

四、示例2:匹配全部

1、执行查询

bash 复制代码
db.shop.find({ fruits: ['apple', 'orange'] });

结果如下:

2、执行过程

bash 复制代码
db.shop.find({ fruits: ['apple', 'orange'] }).explain();

结果如下:

可以看到查询过程中会使用到索引名称为fruits _1的索引

相关推荐
呆瑜nuage4 分钟前
MySQL数据类型全解析
数据库·mysql
XDHCOM7 分钟前
NoSQL查询语言问世,CouchDB与SQLite联手革新数据库交互方式,让数据操作更高效
数据库·nosql·couchdb
黑牛儿12 分钟前
MySQL 实战进阶:从单表优化到分布式数据库适配
数据库·分布式·mysql
momin~12 分钟前
MySQL-part3【数据库约束、表设计】
数据库·mysql
todoitbo12 分钟前
时序数据库选型指南:从大数据场景出发
大数据·数据库·时序数据库
芯盾时代14 分钟前
政务行业面临的网络风险
网络·数据库·网络安全
fire-flyer18 分钟前
第 3 篇:ClickHouse 表结构设计的核心原则
大数据·数据库·clickhouse
FinTech老王18 分钟前
时序数据库存储引擎解密:LSM-Tree vs B-Tree vs 倒排索引,谁最适合时序场景?
数据库·时序数据库·lsm-tree
阿坤带你走近大数据19 分钟前
存储过程在 oracle数据库管理工具里定时自动化运行方案
数据库·oracle·自动化
熬夜的咕噜猫23 分钟前
数据库常用SQL命令
数据库·oracle