Oracle的索引
索引和对应的表应该位于不同的表空间中,oracle能够并行读取位于不同硬盘上的数据,可以避免产生I/O冲突
B树索引:在B树的叶节点中存储索引字段的值与ROWID。
唯一索引和不唯一索引都只是针对B树索引而言.
Oracle最多允许包含32个字段的复合索引
索引创建策略
1.导入数据后再创建索引
2.不需要为很小的表创建索引
3.对于取值范围很小的字段(比如性别字段)应当建立位图索引
4.限制表中的索引的数目
5.为索引设置合适的PCTFREE值
6.存储索引的表空间最好单独设定
创建不唯一索引
create index emp_ename on employees(ename)
tablespace users
storage(......)
pctfree 0;
创建唯一索引
create unique index emp_email on employees(email)
tablespace users;
创建位图索引
create bitmap index emp_sex on employees(sex)
tablespace users;
创建反序索引
create unique index order_reinx on orders(order_num,order_date)
tablespace users
reverse;
创建函数索引(函数索引即可以是普通的B树索引,也可以是位图索引)
create index emp_substr_empno
on employees(substr(empno,1,2))
tablespace users;
修改索引存储参数(与表类似,INITIAL和MINEXTENTS参数在索引建立以后不能再改变)
alter index emp_ename storage(pctincrease 50);
由于定义约束时由oracle自动建立的索引通常是不知道名称的,对这类索引的修改经常是利用alter table ..using index语句进行的,而不是alter index语句
利用下面的语句将employees表中primary key约束对应的索引的PCTFREE参数修改为5
alter table employees enable primary key using index pctfree 5;
清理索引碎片
1.合并索引(只是简单的将B树叶结点中的存储碎片合并在一起,并不会改变索引的物理组织结构)
alter index emp_pk coalesce;
2.重建索引(不仅能够消除存储碎片,还可以改变索引的全部存储参数设置,并且可以将索引移动到其它的表空间中,重建索引
实际上就是再指定的表空间中重新建立一个新的索引,然后删除原来的索引)
alter index emp_pk rebuild;
删除索引
drop index emp_ename;
如果索引中包含损坏的数据块,或者包含过多的存储碎片,需要首先删除这个索引,然后再重建它.
如果索引是在创建约束时由oracle自动产生的,可以通过禁用约束或删除约束的方法来删除对应的索引.
在删除一个表时,oracle会自动删除所有与该表相关的索引.
索引数据字典
all_indexes/dba_indexes/user_indexes 索引的基本信息
all_ind_columns/dba_ind_columns/user_ind_columns 索引对应的字段信息
分享到:
相关推荐
在Oracle中,索引和约束是数据库设计和管理的关键元素,它们对于数据的完整性、查询性能和安全性至关重要。以下是对这些概念的详细解释: **索引(Indexes)** 索引是一种特殊的数据结构,它能够加速对表中数据的...
### Oracle约束详解 在Oracle数据库管理系统中,约束是用于确保数据完整性和一致性的规则或条件。这些约束可以被定义在表级别的字段上,用来限制存储在表中的数据类型。通过实施约束,我们可以确保数据的质量,并...
Oracle 闪回技术详解 Oracle闪回技术是Oracle强大数据库备份恢复机制的一部分,在数据库发生逻辑错误的时候,闪回技术能提供快速且最小损失的恢复。闪回技术旨在快速恢复逻辑错误,对于物理损坏或是介质丢失的错误...
在数据库对象方面,Oracle笔记详细介绍了表的创建和管理,包括数据类型、约束条件、索引的创建和使用。索引是提升查询性能的关键,笔记会涵盖B树索引、位图索引、函数索引等多种类型,并解释它们的适用场景。此外,...
本文将深入探讨Oracle分区表和分区索引的概念、应用场景和实现方式。 1. 使用分区的场景: - 数据量超过2GB的大表,因为大文件在32位操作系统上可能存在限制,并且备份时间较长。 - 包含历史数据的表,如将新数据...
本文将深入探讨Oracle索引的类型、结构以及如何创建和使用。 首先,让我们来了解索引的逻辑分类。逻辑分类主要涉及索引的构建方式: 1. 单列索引(Single Column Index):这种索引针对表中的单一列创建。例如,在...
此外,Unique约束通常会创建一个B-tree索引,以加速数据的查找和更新。 Primary键约束是Unique约束的一个特殊形式,它还定义了一个表的唯一标识符,并且不允许有NULL值。主键列的组合必须是唯一的,通常用于关联...
Oracle数据库的完整性约束和序列规则详解 Oracle数据库中的完整性约束是指数据库中的一种规则,用于增强数据的完整性。Oracle提供了五种完整性约束:Check、NOT NULL、Unique、Primary key和Foreign key。这些约束...
### Oracle系统表详解 Oracle数据库提供了大量的系统表来帮助管理员和开发者更好地理解并管理数据库环境。这些表存储了关于数据库对象的重要信息,如用户、表空间、段等。本文将详细介绍部分重要的Oracle系统表,...
在Oracle中,有两种类型的分区索引:局部索引和全局索引。 局部索引是专门为分区表设计的,它们与表的分区机制相同,即索引的分区与表的分区一一对应。如果索引的列包含分区键作为前几列,这被称为前缀局部索引,...
### Oracle 导入(IMP)与导出(EXP)命令详解 #### 一、概述 在Oracle数据库管理中,导入(Import,IMP)与导出(Export,EXP)是两个非常重要的工具,用于数据迁移、备份恢复等场景。本文将详细介绍这两个命令的...
Oracle 10g数据库详解 Oracle 10g是一款由甲骨文公司(Oracle Corporation)推出的数据库管理系统,属于关系型数据库管理系统(RDBMS)的一种。这个版本在2003年发布,提供了许多增强的功能,包括高可用性、性能...
8. **数据库设计与架构**:理解数据库设计原则,如第三范式,以及如何创建和管理表、视图、索引、约束等对象,对DBA来说同样重要。 9. **监控与性能分析**:通过工具如Oracle Enterprise Manager、Gatherer和SQL ...
在应用分区时,重要的是保持分区的逻辑一致性,即所有分区都必须有相同的数据结构,如列名、数据类型和约束,但物理属性如PCTFREE、PCTUSED和表空间可以不同。分区的透明性意味着SQL和DML操作无需了解数据是否已分区...
### Oracle exp imp命令详解 在Oracle数据库管理领域中,数据导入导出是一项常见的操作,而`exp`(Export)和`imp`(Import)命令则是完成这一任务的强大工具。本文将详细介绍这两个命令的参数和使用方法,帮助读者...
Oracle 数据控制语句详解 在 Oracle 数据库管理系统中,SQL 语言主要分为四大部分:数据查询语言(DQL)、数据操纵语言(DML)、数据定义语言(DDL)以及数据控制语言(DCL)。本篇文章主要关注的是 DML 和 DCL ...
数据字典是数据库的核心部分,存储关于用户、权限、数据对象、表约束和统计信息。数据字典以大写英文字符命名,由sys用户下的表和视图组成。虽然我们不能直接修改数据字典的内容,但可以通过查询来获取信息。 例如...