Oracle 分区索引简介

news2025/1/14 10:16:43

目录

  • 一. 什么是分区索引
  • 二. 分区索引的种类
    • 2.1 局部分区索引(Local Partitioned Index)
    • 2.2 全局分区索引(Global Partitioned Index)
  • 三. 分区索引的创建
  • 四. 分区索引查看
    • 4.1 USER_IND_COLUMNS 表
    • 4.2 USER_INDEXES 表
  • 五. 分区索引的维护
    • 5.1 重新构建索引
    • 5.2 删除索引
  • 六. 项目中的经验教训


一. 什么是分区索引

在 Oracle 数据库中,分区索引(Partitioned Index) 是一种与分区表相关的索引,用于提高分区表上的查询性能和维护效率。
分区索引将数据划分为多个逻辑分区,与表的分区结构紧密关联。这种索引的设计旨在通过限制索引扫描的范围来优化查询性能,尤其是对于大规模数据集。

⏹使用分区索引的契机

  • 为了避免移动数据时重建整个索引,可对索引分区,在重建索引时,只需重建与数据分区相关的索引;
  • 在对分区表进行维护时,为了避免整个表的索引处于不可用状态,可将索引进行分区。当对分区表进行维护时,只需将该分区表的索引置为不可用状态,并不会影响到其它分区索引的使用;
  • 索引表的急剧增长导致索引条目的剧增,使得整个索引表非常大,影响索引速度,需要对索引分区;

二. 分区索引的种类

2.1 局部分区索引(Local Partitioned Index)

  • 每个索引分区与表的一个分区一一对应
  • 如果删除或维护表中的一个分区,只需对应地删除或维护与之相关的索引分区,操作简单。
  • 查询时,Oracle 会自动选择需要访问的索引分区,减少不必要的扫描范围。
  • 适用于对分区表的分区列进行查询的场景。

⏹示意图
在这里插入图片描述

2.2 全局分区索引(Global Partitioned Index)

  • 索引的分区与表的分区没有直接对应关系,而是按索引自己的分区键进行分区。
  • 全局分区索引通常在查询涉及非分区键时使用,可以覆盖整个表的所有分区。
  • 适合数据访问跨分区的情况,且分区键不是查询的过滤条件时使用。

⏹示意图
在这里插入图片描述


三. 分区索引的创建

⏹创建局部(local)分区索引

CREATE INDEX CHARGEFIXEDWORK_DB1 ON CHARGE_FIXED_WORK (CHARGE_REGST_BUSINS_DATE, CHARGE_NO) LOCAL;

⏹创建全局(global)分区索引

CREATE INDEX CHARGEFIXEDWORK_DB2 ON CHARGE_FIXED_WORK (ATZT_NO) GLOBAL PARTITION BY HASH (ATZT_NO) PARTITIONS 4;

四. 分区索引查看

在这里插入图片描述

4.1 USER_IND_COLUMNS 表

SELECT * FROM USER_IND_COLUMNS WHERE TABLE_NAME = 'CHARGE_FIXED_WORK' ORDER BY INDEX_NAME;

在这里插入图片描述

4.2 USER_INDEXES 表

SELECT
    INDEX_NAME
    , INDEX_TYPE
    , TABLE_OWNER
    , TABLE_NAME
    , TABLE_TYPE
    , TO_CHAR(last_analyzed, 'YYYY/MM/DD HH24:MI:SS') AS LAST_ANALYZED
FROM
    USER_INDEXES 
WHERE
    INDEX_NAME = 'CHARGEFIXEDWORK_DB1';

在这里插入图片描述


五. 分区索引的维护

5.1 重新构建索引

⏹重新构建全局索引

ALTER INDEX global_index_name REBUILD;
  • 分区表的某些操作(如 TRUNCATE PARTITIONDROP PARTITION)会导致全局索引失效,需要重新维护。
  • 在删除指定分区时,重新构建全局索引
ALTER TABLE partitioned_table_name TRUNCATE PARTITION partition_name UPDATE GLOBAL INDEXES;

⏹重新构建本地索引的某个分区

ALTER INDEX local_index_name REBUILD PARTITION partition_name;

5.2 删除索引

  • 删除整个索引(包括所有分区)
  • 适用于所有类型的索引,包括全局索引和本地索引。
DROP INDEX index_name;
  • 删除本地索引指定分区
  • 本地索引和分区一一对应,每个分区都会有自己的本地索引
    • 例如我们一共有4个分区,名称分别叫做SYS_P564,SYS_P565,SYS_P566,SYS_P567
    • 这4个分区都有自己的本地索引,名称叫做CHARGEFIXEDWORK_DB1
    • 我们现在只想删除SYS_P567分区上的本地索引,保留剩余分区的本地索引
ALTER INDEX local_index_name DROP PARTITION partition_name;

在这里插入图片描述


六. 项目中的经验教训

从XX年X月开始,围绕DB出现了各种竞合,其中对于同一个index的登录处理时,TXindex contention的问题频发。
也是从去年开始,几乎每个月都会人工的做下面几点,来解决此问题。

  • index的本地化(把global index变成local index)
  • 不要的index的删除

经调查,往往是在数据parten比较少的项目上加的index会有上述问题。
比如,登录年月日,区分等。
这种项目在登录时,一般只会登录当天的日期,或登录少数的区分值。
如果这些项目上做了gobalindex的话,根据DDL的定义,往往有256个分区来存储这个index。
在登录处理里,写入index的时候,oracle会优先把内容一样的数值放到相同的分区中以便今后的检索查找方便。
但这样一来,tps比较高的登录机能,就会对某一个分区进行高速的写入,最终导致TXindex contention的发生。
而使用local Index的话,则发生竞合的概率会变的很低。

★今后的要求★
案件开发时,需要加新TBL的时候,如果表里面有日期,区分等上述的项目并且要对这样的项目添加index的话,
要检讨是否应该用local index

⏹参考

在插入分区时,oracle的Local index和Global index的算法有以下不同之处:

Local Index算法:对于Local Index,每个分区会有独立的索引副本,其索引的建立和维护只针对当前分区的数据。
当插入新的分区时,oracle会为该分区建立独立的索引副本,这些分区索引可以并行建立,
因此在分区插入时可以获得更好的性能。这对于分区表的查询和维护操作来说是最有效的选择。

Global Index算法:对于G1obal Index,所有分区共字同一个索引副本,索引的建立和维护是针对整个表的。
因此,在插入新的分区时,需要对整个索引进行更新和重建,这可能涉及到大量的数据移动和索引重建,导致性能下降。
因此,在插入分区时,Global Index相对于Local Index来说性能较低。

综上所述,当频繁进行分区插入操作时,Local Index相对于Global ndex来说更加高效和适用。
但是Local Index也对存储需求有较高的要求,因为每个分区都需要存放一个独立的索引副本。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2276427.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

JDK安装配置保姆级教程【图文详解】

目录 一. JDK介绍 二. JDK下载 三. JDK安装 四. 配置环境 五. 验证安装 一. JDK介绍 Java 环境分JDK 和JRE ,JDK就是Java Development Ki,JDK是面向开发人员使用的SDK,它提供了Java的开发环境和运行环境。本文以Windows 11系统,JD…

浅谈云计算01 | 云计算服务的特点

在当今数字化时代,云计算作为一种强大的技术解决方案,正逐渐改变着企业和个人对信息技术的使用方式。本文将详细探讨云计算的五个主要特点,包括按需自助服务、广泛的网络接入、资源池化、快速弹性伸缩以及可计量服务。 一、按需自助服务 云…

【Git版本控制器--1】Git的基本操作--本地仓库

目录 初识git 本地仓库 认识工作区、暂存区、版本库 add操作与commit操作 master文件与commit id 修改文件 版本回退 撤销修改 删除文件 初识git Git 是一个分布式版本控制系统,主要用于跟踪文件的更改,特别是在软件开发中。 为什么要版本…

Unity使用Vuforia插件进行AR开发

零、最终效果 Unity使用Vuforia插件进行AR开发 一、资源准备 1、在Unity中添加Vuforia插件 (1)在UnityAssetStore中搜索Vuforia插件并添加到自己的资源中 网页地址:https://assetstore.unity.com/packages/templates/packs/vuforia-engine…

瑞芯微 RK 系列 RK3588 使用 ffmpeg-rockchip 实现 MPP 视频硬件编解码-代码版

前言 在上一篇文章中,我们讲解了如何使用 ffmpeg-rockchip 通过命令来实现 MPP 视频硬件编解码和 RGA 硬件图形加速,在这篇文章,我将讲解如何使用 ffmpeg-rockchip 用户空间库(代码)实现 MPP 硬件编解码。 本文不仅适…

Web前端界面开发

前沿:介绍自适应和响应式布局 自适应布局:-----针对页面1个像素的变换而变化 就是我们上一个练习的效果 我们的页面效果,随着我们的屏幕大小而发生适配的效果(类似等比例) 如:rem适配 和 vw/vh适配 …

OpenCV基础:视频的采集、读取与录制

从摄像头采集视频 相关接口 - VideoCapture VideoCapture 用于从视频文件、摄像头或其他视频流设备中读取视频帧。它可以捕捉来自多种源的视频。 主要参数: cv2.VideoCapture(source): source: 这是一个整数或字符串,表示视频的来源。 如果是整数&a…

C++内存泄露排查

内存泄漏是指程序动态分配的内存未能及时释放,导致系统内存逐渐耗尽,最终可能造成程序崩溃或性能下降。在C中,内存泄漏通常发生在使用new或malloc等分配内存的操作时,但没有正确地使用delete或free来释放这块内存。 在日常开发过程…

Golang 简要概述

文章目录 1. Golang 的学习方向2. Golang 的应用领域2.1 区块链的应用开发2.2 后台的服务应用2.3 云计算/云服务后台应用 1. Golang 的学习方向 Go 语言,我们可以简单的写成 Golang 2. Golang 的应用领域 2.1 区块链的应用开发 2.2 后台的服务应用 2.3 云计算/云服…

51c自动驾驶~合集46

我自己的原文哦~ https://blog.51cto.com/whaosoft/13050104 #世界模型会是L3自动驾驶的唯一解吗 三维空间占有率(3D Occupancy)预测的目的是预测三维空间中的每个体素是否被占有,如果被占有,则对应的体素将被标记。3D Semant…

从CentOS到龙蜥:企业级Linux迁移实践记录(龙蜥开局)

引言: 在我们之前的文章中,我们详细探讨了从CentOS迁移到龙蜥操作系统的基本过程和考虑因素。今天,我们将继续这个系列,重点关注龙蜥系统的实际应用——特别是常用软件的安装和配置。 龙蜥操作系统(OpenAnolis&#…

WMS仓库管理系统,Vue前端开发,Java后端技术源码(源码学习)

一、项目背景和建设目标 随着企业业务的不断扩展,仓库管理成为影响生产效率、成本控制及客户满意度的重要环节。为了提升仓库作业的透明度、准确性和效率,本方案旨在构建一套全面、高效、易用的仓库管理系统(WMS)。该系统将涵盖库…

Docker Search失败,但是Pull成功的解决方法(环境:腾讯云服务器CentOS7系统安装Docker)

Docker Search失败,但是Pull成功的解决方法(环境:腾讯云服务器CentOS7系统安装Docker) 背景解决思路 背景 在安装完成Docker后,成功启动Docker(Systemctl start Docker),使用搜索镜像命令(Dock…

ClickHouse vs StarRocks 选型对比

一、面向列存的 DBMS 新的选择 Hadoop 从诞生已经十三年了,Hadoop 的供应商争先恐后的为 Hadoop 贡献各种开源插件,发明各种的解决方案技术栈,一方面确实帮助很多用户解决了问题,但另一方面因为繁杂的技术栈与高昂的维护成本&…

慧集通(DataLinkX)iPaaS集成平台-业务建模之业务对象(二)

3.UI模板 当我们选择一条已经建好的业务对象点击功能按钮【UI模板】进入该业务对象的UI显示配置界面。 右边填写的是UI模板的编码以及对应名称;菜单界面配置以业务对象UI模板编码获取显示界面。 3.1【列表-按钮】 展示的对应业务对象界面的功能按钮配置&#xff1…

TCL小蓝翼新风空调亮相CES2025,斩获智慧新风技术创新大奖

1月7日-11日,被称为“科技界春晚”的CES 2025(国际消费类电子产品展览会)在美国拉斯维加斯举行。 本届CES,TCL小蓝翼新风空调更是惊艳亮相TCL展区,以领先的健康新风及AI技术,斩获CES2025 智慧新风技术创新…

【I/O编程】UNIX文件基础

IO编程的本质是通过 API 操作 文件。 什么是 IO I - Input 输入O - Output 输出 这里的输入和输出都是站在应用(运行中的程序)的角度。外部特指文件。 这里的文件是泛指,并不是只表示存在存盘中的常规文件。还有设备、套接字、管道、链接…

【计算机网络】深入浅出计算机网络

第一章 计算机网络在信息时代的作用 计算机网络已由一种通信基础设施发展成一种重要的信息服务基础设施 CNNIC 中国互联网网络信息中心 因特网概述 网络、互联网和因特网 网络(Network)由若干结点(Node)和连接这些结点的链路…

在IDEA上运行Java项目

新建一个项目,下面创建模块,然后在src下新建包名,最后见类(class) 设置主题 settings>apparence 设置字体 Editor> Font 设置注释 Editor>Color Scheme>Language Defaults>Comments 设置自动导包 …

ASO优化之应用程序本地化的类型和策略

应用程序本地化是进入全球移动电话用户市场的关键一步。但它到底是什么?应用程序本地化是指定制您的应用程序以适应多种语言、文化、语言和区域设置。这不仅仅是翻译,它考虑了地区法规、文化细微差别和当地偏好。本地化良好的应用程序可以引起用户的共鸣…