Oracle 分区索引简介

目录

  • 一. 什么是分区索引
  • 二. 分区索引的种类
    • 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也对存储需求有较高的要求,因为每个分区都需要存放一个独立的索引副本。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Spring bean的生命周期和扩展

接AnnotationConfigApplicationContext流程看实例化的beanPostProcessor-CSDN博客,以具体实例看bean生命周期的一些执行阶段 bean生命周期流程 生命周期扩展处理说明实例化:createBeanInstance 构造方法, 如Autowired的构造方法注入依赖bean 如UserSer…

【再谈设计模式】模板方法模式 - 算法骨架的构建者

一、引言 在软件工程、软件开发过程中,我们经常会遇到一些算法或者业务逻辑具有固定的流程步骤,但其中个别步骤的实现可能会因具体情况而有所不同的情况。模板方法设计模式(Template Method Design Pattern)就为解决这类问题提供了…

01 Oracle自学环境搭建(Windows系统)

1 Oracle12C安装 1.1 下载 官网地址:https://www.oracle.com/ 进入官网→Resource→Customer Downloads 如果没有登录,会提示登录后后才能下载 选择适合自己的版本(我电脑是Windows系统 64位) 选择需要的安装包进行下载 双击下载…

java语法知识(二)

1. class文件可以直接拖动到idea中,显示源码。 2.idea快捷键: sout : System.out.println 输出内容.sout :---》 System.out.println(输出内容); psvm: public static void main() 格式化:ctrl altL 复制粘贴:ctrld 3.注释…

macos python环境安装

安装的问题 mac 安装 python brew install python 通过brew安装的python安装路径 打开终端,输入brew search python: 为啥会被安装在这里 Frameworks 的用途:/Library/Frameworks 是 macOS 系统中专门用于存放框架的目录。框架是一种结构…

计算机网络 笔记 数据链路层 2

1,信道划分: (1)时分复用TDM 将时间等分为“TDM帧”,每个TDM帧内部等分为m个时隙,m个用户对应m个时隙 缺点:每个节点只分到了总带宽的1/m,如果有部分的1节点不发出数据,那么就会在这个时间信道被闲置,利用…

ElasticSearch在Windows环境搭建测试

引子 也持续关注大数据相关内容一段时间,大数据内容很多。想了下还是从目前项目需求侧出发,进行相关学习。Elasticsearch(ES)是位于 Elastic Stack(ELK stack) 核心的分布式搜索和分析引擎。Logstash 和 B…

计算机网络 笔记 网络层1

网络层功能概述 主要的任务是把分组从源端传输到目的端,为分组交换网上的不同主句提供通信服务,网络层的传输单位是数据报。 主要的功能; 1,路由选择:路由选择指网络层根据特定算法,为数据包从源节点到目…

Rubyer-WPF:打造优雅、精致的 WPF 用户界面

在桌面应用开发领域,WPF(Windows Presentation Foundation)凭借其强大的 UI 设计能力和丰富的功能,始终是开发者们青睐的工具之一。今天,我将为大家介绍一款专注于 WPF UI 设计的优秀项目——Rubyer-WPF,它…

设计模式 行为型 访问者模式(Visitor Pattern)与 常见技术框架应用 解析

访问者模式(Visitor Pattern)是一种行为设计模式,它允许你在不改变元素类的前提下定义作用于这些元素的新操作。这种模式将算法与对象结构分离,使得可以独立地变化那些保存在复杂对象结构中的元素的操作。 假设我们有一个复杂的对…

继承多态语法糖

抽象类(通用) 子类继承父类方法后,这个子类对象如果执行方法的话,只要子类重写了就执行子类的,不执行父类的。 /*** 功能:* 作者:IT伟* 日期:2025/1/13 19:20*/ // 抽象类 A abstract class A {// 构造函…

MarS:一个由生成基础模型驱动的金融市场模拟引擎

“MARS: A FINANCIAL MARKET SIMULATION ENGINE POWERED BY GENERATIVE FOUNDATION MODEL” 项目主页:https://mars-lmm.github.io/ 论文地址:https://arxiv.org/pdf/2409.07486 Github地址:https://github.com/microsoft/MarS/ 摘要 生成…

macOS 使用 FreeRDP 远程访问 Windows:完整指南20250109

🖥️ macOS 使用 FreeRDP 远程访问 Windows:完整指南 引言 随着远程办公需求的快速增长,跨平台远程管理已经成为不可或缺的技能之一。作为一款开源轻量的远程桌面协议实现工具,FreeRDP 为 macOS 用户提供了一个简单、高效的解决…

两分钟解决 :![rejected] master -> master (fetch first) , 无法正常push到远端库

目录 分析问题的原因解决 分析问题的原因 在git push的时候莫名遇到这种情况 若你在git上修改了如README.md的文件。由于本地是没有README.md文件的,所以导致 远端仓库git和本地不同步。 将远端、本地进行合并就可以很好的解决这个问题 注意:直接git pu…

计算机图形学【绘制立方体和正六边形】

工具介绍 OpenGL:一个跨语言的图形API,用于渲染2D和3D图形。它提供了绘制图形所需的底层功能。 GLUT:OpenGL的一个工具库,简化了窗口创建、输入处理和其他与图形环境相关的任务。 使用的函数 1. glClear(GL_COLOR_BUFFER_BIT |…

springboot高校教室资源管理平台

Spring Boot高校教室资源管理平台是一个基于Spring Boot框架开发的高校教室资源管理系统。 一、平台背景与意义 随着高校规模的不断扩大,教室资源的管理变得日益复杂。传统的管理方式往往依赖于人工记录和纸质文件,不仅效率低下,而且容易出…

[笔记] 使用 Jenkins 实现 CI/CD :从 GitLab 拉取 Java 项目并部署至 Windows Server

随着软件开发节奏的加快,持续集成(CI)和持续部署(CD)已经成为确保软件质量和加速产品发布的不可或缺的部分。Jenkins作为一款广泛使用的开源自动化服务器,为开发者提供了一个强大的平台来实施这些实践。然而…

正点原子STM32F103战舰版电容触摸键学习

一、tpad.h代码 #ifndef __TPAD_H #define __TPAD_H#include "./SYSTEM/sys/sys.h"/******************************************************************************************/ /* TPAD 引脚 及 定时器 定义 *//* 我们使用定时器的输入捕获功能, 对TPAD进行检…

JVM:ZGC详解(染色指针,内存管理,算法流程,分代ZGC)

1,ZGC(JDK21之前) ZGC 的核心是一个并发垃圾收集器,所有繁重的工作都在Java 线程继续执行的同时完成。这极大地降低了垃圾收集对应用程序响应时间的影响。 ZGC为了支持太字节(TB)级内存,设计了基…

zerox - 使用视觉模型将 PDF 转换为 Markdown

7900 Stars 478 Forks 39 Issues 17 贡献者 MIT License Python 语言 代码: https://github.com/getomni-ai/zerox 主页: OmniAI. Automate document workflows 更多AI开源软件:AI开源 - 小众AI zerox基于视觉模型 API 服务,提供了将 PDF 文档转化为 Mar…