• 国产集中式数据库对象评测 — 索引

国产集中式数据库对象评测 — 索引

2025-04-27 10:41:13 栏目:宝塔面板 35 阅读

1. 对象(索引)能力概述

先来看看各家数据库产品在索引能力的大致表现如何。限于宽度,这里拆分为两个表格。

1.png

2.png

2. 对象(索引)能力详解

1).索引类型

随着数据库对数据模式的支持不断丰富及使用场景的更加多元,更多索引类型的支持成为必然。除了传统的B+树索引外,正有更多的索引类型被主持。下面列举了一些索引类型及使用的场景等。当然从实际使用来看,传统B+树仍然为主流,也是被大家广泛使用的。从国产数据库支持情况来看,差异较大;PG系产品相对有一定优势,支持了更为丰富的索引类型。

3.png

2).索引结构与存储

索引在存储结构通常采用的是B+树的结构,根据索引类型的不同,也有采用其他结构的。在存储组织格式上,聚集与非聚集索引页都有存在,一般数据库也都支持两种方式。

4.png

3).索引对象

针对索引对象,不同数据库差异较大。除了通常意义针对字段值进行索引外,还有数据库支持字段值的反转后进行索引,这将有利于消除热点。有些数据库还支持对表达式、函数进行索引,这无疑增加了索引的适应场景。此外,还有数据库支持对部分字段值(如前缀)或部分记录进行索引。

4).分区索引

索引对分区能力的支持,是在应对大数据量情况下的关键技术。从个人过去的使用来看,通常慎选全局索引,而尽量选择代价较低的本地索引。从国产数据库来看,也都支持了这两种类型,除了MySQL对此能力相对较弱外,其他都差不多。这里差异主要体现在分区索引维护上面。

5.png

5).索引优化

索引能否发挥更大作用,取决于优化器能能否充分地利用索引。这里有一些常见的优化手段,包括索引覆盖扫描、索引条件下推、索引跳跃扫描等等。这里稍微吐槽下,国内数据库这部分介绍的不多,搜索也得不到有用的信息,因此可能信息不够完整。

6).索引维护与开发

针对运维层面,索引会带来部分工作,例如定期监控索引的状态、使用情况等。如数据库提供了良好的可观察性和便捷的维护方式会带来很大收益。针对开发层面,一方面如何使用好索引,另一方面则是针对当前情况能给出一些索引建议。这两点,Oracle做得相对完善,国产数据库还有一定距离。

本文地址:https://www.yitenyun.com/105.html

搜索文章

Tags

数据库 API FastAPI Calcite 电商系统 MySQL Web 应用 异步数据库 数据同步 ACK 双主架构 循环复制 Deepseek 宝塔面板 Linux宝塔 Docker 生命周期 序列 核心机制 JumpServer JumpServer安装 堡垒机安装 Linux安装JumpServer esxi esxi6 root密码不对 无法登录 web无法登录 Windows Windows server net3.5 .NET 安装出错 宝塔面板打不开 宝塔面板无法访问 SSL 堡垒机 跳板机 HTTPS 查看硬件 Linux查看硬件 Linux查看CPU Linux查看内存 无法访问宝塔面板 Windows宝塔 Mysql重置密码 HTTPS加密 连接控制 机制 ES 协同 Oracle 处理机制 Serverless 无服务器 语言 OB 单机版 Spring SQL 动态查询 scp Linux的scp怎么用 scp上传 scp下载 scp命令 技术 存储 运维 缓存方案 缓存架构 缓存穿透 分页查询 索引 Rsync 架构 InnoDB 日志文件 MIXED 3 响应模型 修改DNS Centos7如何修改DNS RocketMQ 长轮询 配置 监控 HexHub Redis 电商 系统 Linux 安全 服务器 聚簇 非聚簇 MySQL 9.3 异步化 防火墙 黑客 sftp 服务器 参数 查询 数据 主库 group by 自定义序列化 数据库锁 SQLark PostgreSQL 管理口 业务 开源 存储引擎 Doris SeaTunnel 人工智能 向量数据库 推荐系统 SQLite-Web SQLite 数据库管理工具 R edis 线程 线上 库存 预扣 MVCC PG DBA 加密 场景 流量 工具 共享锁 网络架构 网络配置 AI 助手 Ftp redo log 重做日志 ​Redis 机器学习 推荐模型 信息化 智能运维 数据备份 RDB AOF Redis 8.0 高可用 Canal B+Tree ID 字段 优化 万能公式 • 索引 • 数据库 缓存 GreatSQL 连接数 Postgres OTel Iceberg Python INSERT COMPACT 核心架构 订阅机制 同城 双活 网络故障 Hash 字段 自动重启 Web 云原生 IT运维 微软 SQL Server AI功能 prometheus Alert 不宕机 大模型 OAuth2 Token Netstat Linux 服务器 端口 引擎 性能 分库 分表 SVM Embedding 高效统计 今天这篇文章就跟大家 虚拟服务器 虚拟机 内存 向量库 Milvus Entity 开发 ZODB 单点故障 Undo Log 容器化 DBMS 管理系统 MongoDB 容器 sqlmock LRU 崖山 新版本 mini-redis INCR指令 JOIN 悲观锁 乐观锁 openHalo 数据集成工具 窗口 函数 分布式 集中式 SpringAI 排行榜 排序 磁盘架构 QPS 高并发 Testcloud 云端自动化 Redka 数据脱敏 加密算法 Redisson 锁芯 PostGIS 大表 业务场景 StarRocks 数据仓库 分页 数据结构 EasyExcel MySQL8 Recursive 聚簇索引 非聚簇索引 数据类型 模型 启动故障 意向锁 记录锁 分布式架构 分布式锁​ Pottery 原子性 AIOPS R2DBC IT Caffeine CP 工具链 事务 Java 发件箱模式 SSH 网络 MCP 开放协议 InfluxDB RAG HelixDB 1 池化技术 连接池 Web 接口 部署 dbt 数据转换工具 filelock 对象 数据分类 速度 服务器中毒 事务隔离 字典 传统数据库 向量化 优化器 读写 Go 数据库迁移 仪表盘 数据页 Order 单线程 双引擎 频繁 Codis 分页方案 排版 线程安全 LLM Crash 代码 List 类型 事务同步 UUIDv7 主键 订单 Pump 日志 Ansible