oracle:索引(B树索引,位图索引,分区索引,主键索引,唯一索引,联合索引/组合索引,函数索引)

索引通过存储列的排序值来加快对表中数据的访问速度,帮助数据库系统快速定位到所需数据,避免全表扫描

B树索引(B-Tree Index)

B树索引是一种平衡树结构,适合处理范围查询和精确查找。它的设计目标是保持数据有序,并支持高效的插入、删除和查找操作。是 Oracle 数据库中一种最常见的索引类型, 索引没有指定索引类型时默认是B树索引

语法 : 根据表中的某个字段创建索引

索引名命名规范: idx_表名_字段名

(不强制,只是相对规范,其他起名方式也可以)

位图索引(Bitmap Index)

主要用于处理低基数列(即列中唯一值较少的列,如性别、状态等)。位图索引通过使用位图(bitmap)来表示数据的存在与否,适合在数据仓库或决策支持系统(DSS)中使用,尤其是在需要处理大量静态数据和复杂查询的场景中。

语法

分区索引(Partitioned Index)

是与分区表(Partitioned Table)相关联的索引。分区表是将大表数据按某种规则(如范围、列表、哈希等)分成多个较小的分区(Partition),而分区索引则是为这些分区创建的索引。分区索引可以显著提高大表的查询性能,尤其是在数据量非常大的情况下。

分类

区别: 当表分区发生变化(如添加、删除、合并分区)时,本地分区索引会自动同步, 全局分区索引可能需要手动维护 

语法

以上语法没有指定索引实现方式, 默认是B树索引

主键索引和唯一索引

主键索引和唯一索引通常都是使用B树索引来实现的, 通常不将主键索引和唯一索引指定为位图索引/哈希索引。

共同点:

1.唯一索引和主键索引都是用来保证数据的唯一性的;

2.都可以在建表时定义

区别:

1.主键索引不能包含NULL值, 唯一索引可以有NULL值且可以出现多次(因为NULL不等于任何值,包括它自己)。

2.一个表只能有一个主键索引,但可以有多个唯一索引

主键索引的语法

主键索引字段是单个时是单一主键索引, 字段有2个或以上时是复合主键索引

唯一索引的语法

联合索引/组合索引

指在多个列上创建的索引。它适用于查询条件中同时涉及多个列的场景, 默认属于B树索引,不支持直接将联合索引创建为哈希索引

索引(a , b , c) 有3个字段,相当于建了3个索引, 即索引(a) , 索引(a , b) , 索引(a, b , c)

联合索引的顺序影响查询效率,应根据查询频率和选择性设计索引。高选择性的列应放在前面

最左原则:

联合索引按从左到右的顺序匹配,查询条件必须包含最左侧的列,否则索引可能失效。例如,索引为 (A, B, C),查询条件应包含 A,否则索引可能无法使用

如果联合索引是 (A, B, C),而查询条件是 A 和 C(即缺少中间的 B),联合索引部分有效

函数索引

基于表达式或函数创建的索引。它适用于查询条件中包含函数或表达式的场景, 常用于优化复杂的计算列查询以及大小写不敏感的查询, 默认属于B树索引, 不支持将函数索引直接指定为哈希索引

指定位图索引的语法

 

查看索引

查看索引信息

USER_INDEXES 视图包含了当前用户拥有的所有索引的信息

ALL_INDEXES 视图包含了当前用户有权限访问的所有索引的信息

DBA_INDEXES 视图包含了数据库中所有索引的信息。你需要有 DBA 权限才能访问这个视图。

查看索引包含的列

查看索引的储存信息

 

USER_SEGMENTS是一个系统视图, 用于描述当前用户所拥有的对象的段(Segment)的存储分配情况, 段是 Oracle 数据库中分配存储空间的逻辑单位,用于存储表、索引、分区、簇等对象的数据

索引选择:如果聚簇因子较高,CBO 可能会认为全表扫描的成本更低,从而选择全表扫描而不是索引扫描

查看索引的分区信息(如果索引是分区索引)

获取索引的DDL

通过对象面板查看索引

查看索引 :     Tables>>表名>>查看

查看索引DDL:          Tables>>表名>>DBMS_元数据(D)>>DDL

删除索引

授权sql

如果尝试删除一个不存在的索引,数据库会抛出一个错误

验证索引是否已删除

删除与约束相关的索引

如果索引是某个约束(如主键或唯一约束)的一部分,Oracle 会自动为该约束创建索引。这种情况下,不能直接删除索引,需要删除约束, 删除约束= 删除相应的索引

ALTER TABLE employee
DROP CONSTRAINT 约束名;

删除分区索引

直接使用 DROP INDEX 删除整个索引,或者删除特定的分区

ALTER INDEX 分区索引名称
DROP PARTITION 分区名;

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【DeepSeek背后的技术】系列一:混合专家模型(MoE)

目录 1 概述2 稀疏性3 微调3.1 令牌的负载均衡3.2 使用HuggingFace微调MoE模型3.3 专家如何学习3.4 专家的数量3.5 微调 4 提速4.1 并行计算4.2 容量因子和通信开销4.3 部署技术4.4 高效训练 5 MoE和稠密模型对比6 为什么是替换FFN层6.1 FFN层的角色与特性6.2 MoE的优势与FFN的…

AI技术在SEO关键词优化中的应用策略与前景展望

内容概要 在数字营销的快速发展中,AI技术逐渐成为SEO领域的核心驱动力。其通过强大的数据分析和处理能力,不仅改变了我们优化关键词的方式,也提升了搜索引擎优化的效率和效果。在传统SEO中,关键词的选择与组合常依赖人工经验和直…

!力扣 84. 柱状图中最大矩形

给定 n 个非负整数,用来表示柱状图中各个柱子的高度。每个柱子彼此相邻,且宽度为 1 。 求在该柱状图中,能够勾勒出来的矩形的最大面积。 示例 1: 输入:heights [2,1,5,6,2,3] 输出:10 解释:最大的矩形为…

ieee模版如何修改参考文献的格式以及多作者省略等

在用latex写论文的时候,会遇到各种模板,如果你要投IEEE的期刊或者会议,就得使用相应的latex模板。对于参考文献很多模版不一样的有些使用文本导入 有些使用的是bib 格式,因此记录一下如何修改IEEE参考文献的格式已经对应的多作者进…

【产品经理学习案例——AI翻译棒出海业务】

前言: 本文主要讲述了硬件产品在出海过程中,翻译质量、翻译速度和本地化落地策略是硬件产品规划需要考虑的核心因素。针对不同国家,需要优化翻译质量和算法,关注市场需求和文化差异,以便更好地满足当地用户的需求。同…

Jenkins 触发构建的几种常见方式

为了实现自动化构建,Jenkins 提供了多种触发构建的方式。这些触发方式可以根据开发团队的需求来选择,使得构建过程更加灵活和高效。 1. 手动触发构建 手动触发构建是最简单的一种方式,通常用于开发人员或管理员手动启动构建任务。 步骤: 登录 Jenkins 后,进入某个项目(…

全栈开发:使用.NET Core WebAPI构建前后端分离的核心技巧(一)

目录 cors解决跨域 依赖注入使用 分层服务注册 缓存方法使用 内存缓存使用 缓存过期清理 缓存存在问题 分布式的缓存 cors解决跨域 前后端分离已经成为一种越来越流行的架构模式,由于跨域资源共享(cors)是浏览器的一种安全机制,它会阻止前端应用…

Python写一个爱心

项目代码: import random from math import sin, cos, pi, log from tkinter import *# 定义窗口的大小 CANVAS_WIDTH 640 CANVAS_HEIGHT 480 CANVAS_CENTER_X CANVAS_WIDTH / 2 CANVAS_CENTER_Y CANVAS_HEIGHT / 2 IMAGE_ENLARGE 11 # 定义爱心的颜色 HEART_…

leetcode——二叉树的最近公共祖先(java)

给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为:“对于有根树 T 的两个节点 p、q,最近公共祖先表示为一个节点 x,满足 x 是 p、q 的祖先且 x 的深度尽可能大(一个节点也可以是它自己的…

Android学习制作app(ESP8266-01S连接-简单制作)

一、理论 部分理论见arduino学习-CSDN博客和Android Studio安装配置_android studio gradle 配置-CSDN博客 以下直接上代码和效果视频,esp01S的收发硬件代码目前没有分享,但是可以通过另一个手机网络调试助手进行模拟。也可以直接根据我的代码进行改动…

20250202在Ubuntu22.04下使用Guvcview录像的时候降噪

20250202在Ubuntu22.04下使用Guvcview录像的时候降噪 2025/2/2 21:25 声卡:笔记本电脑的摄像头自带的【USB接口的】麦克风。没有外接3.5mm接口的耳机。 缘起:在安装Ubuntu18.04/20.04系统的笔记本电脑中直接使用Guvcview录像的时候底噪很大! …

MySQL子查询

一、子查询的概述 1、理解:可以理解为嵌套查询,查询的内部进行查询 2、称谓规范:外查询(主查询)、内查询(子查询),这种称呼是相对的。 子查询(内查询)在主查…

MongoDb user自定义 role 添加 action(collStats, EstimateDocumentCount)

使用 mongosh cd mongsh_bin_path mongosh “mongodb://user:passip:port/db”这样就直接进入了对应的db 直接输入: 这样 role “read_only_role" 就获得了3个 action, 分别是 查询,列举集合,集合元数据查询 P.S: 如果没有 …

结构体DMA串口接收比特错位

发送: 显示: uint16_t接收时候会比特错位。

经典本地影音播放器MPC-BE.

经典本地影音播放器MPC-BE 链接:https://pan.xunlei.com/s/VOIAZbbIuBM1haFdMYCubsU-A1?pwd4iz3# MPC-BE(Media Player Classic Black Edition)是来自 MPC-HC(Media Player Classic Home Cinema)的俄罗斯开发者重新…

python学opencv|读取图像(五十四)使用cv2.blur()函数实现图像像素均值处理

【1】引言 前序学习进程中,对图像的操作均基于各个像素点上的BGR值不同而展开。 对于彩色图像,每个像素点上的BGR值为三个整数,因为是三通道图像;对于灰度图像,各个像素上的BGR值是一个整数,因为这是单通…

【开源免费】基于Vue和SpringBoot的工作流程管理系统(附论文)

本文项目编号 T 193 ,文末自助获取源码 \color{red}{T193,文末自助获取源码} T193,文末自助获取源码 目录 一、系统介绍二、数据库设计三、配套教程3.1 启动教程3.2 讲解视频3.3 二次开发教程 四、功能截图五、文案资料5.1 选题背景5.2 国内…

IntelliJ IDEA远程开发代理远程服务器端口(免费内网穿透)

IntelliJ IDEA远程开发代理远程服务器端口(免费内网穿透)(JetBrains家的其他IDE应该也支持) 之前看到宇宙第一IDE VS Code好像默认代理了远程的端口,但是一直没找到IDEA的同类功能,这次终于发现了 以Intell…

文字显示省略号

多行文本溢出显示省略号

STM32_SD卡的SDIO通信_DMA读写

本篇,将使用CubeMXKeil,创建一个SD卡的DMA读写工程。 目录 一、简述 二、CubeMX 配置 SDIO DMA 三、Keil 编辑代码 四、实验效果 实现效果,如下图: 一、简述 上篇已简单介绍了SD、SDIO,本篇不再啰嗦,…