Oracle的索引
    索引和对应的表应该位于不同的表空间中,oracle能够并行读取位于不同硬盘上的数据,可以避免产生I/O冲突
B树索引:在B树的叶节点中存储索引字段的值与ROWID。
唯一索引和不唯一索引都只是针对B树索引而言.
Oracle最多允许包含32个字段的复合索引

索引创建策略
1.导入数据后再创建索引
2.不需要为很小的表创建索引
3.对于取值范围很小的字段(比如性别字段)应当建立位图索引
4.限制表中的索引的数目
5.为索引设置合适的PCTFREE值
6.存储索引的表空间最好单独设定

创建不唯一索引

Sql代码  
  1. create index emp_ename on employees(ename)
  2. tablespace users
  3. storage(......)
  4. pctfree 0;
create index emp_ename on employees(ename)
tablespace users
storage(......)
pctfree 0; 

创建唯一索引

Sql代码  
  1. create unique index emp_email on employees(email)
  2. tablespace users;
create unique index emp_email on employees(email)
tablespace users; 

创建位图索引

Sql代码  
  1. create bitmap index emp_sex on employees(sex)
  2. tablespace users;
create bitmap index emp_sex on employees(sex)
tablespace users; 

创建反序索引

Sql代码  
  1. create unique index order_reinx on orders(order_num,order_date)
  2. tablespace users
  3. reverse;
create unique index order_reinx on orders(order_num,order_date)
tablespace users
reverse; 

创建函数索引(函数索引即可以是普通的B树索引,也可以是位图索引)

Sql代码  
  1. create index emp_substr_empno
  2. on employees(substr(empno,1,2))
  3. tablespace users;
create index emp_substr_empno
on employees(substr(empno,1,2))
tablespace users; 

修改索引存储参数(与表类似,INITIAL和MINEXTENTS参数在索引建立以后不能再改变)

Sql代码  
  1. alter index emp_ename storage(pctincrease 50);
alter index emp_ename storage(pctincrease 50); 

由于定义约束时由oracle自动建立的索引通常是不知道名称的,对这类索引的修改经常是利用alter table ..using index语句进行的,而不是alter index语句

利用下面的语句将employees表中primary key约束对应的索引的PCTFREE参数修改为5

Sql代码  
  1. alter table employees enable primary key using index pctfree 5;
alter table employees enable primary key using index pctfree 5; 

清理索引碎片
1.合并索引(只是简单的将B树叶结点中的存储碎片合并在一起,并不会改变索引的物理组织结构)

Sql代码  
  1. alter index emp_pk coalesce;
alter index emp_pk coalesce; 

2.重建索引(不仅能够消除存储碎片,还可以改变索引的全部存储参数设置,并且可以将索引移动到其它的表空间中,重建索引
实际上就是再指定的表空间中重新建立一个新的索引,然后删除原来的索引)

Sql代码  
  1. alter index emp_pk rebuild;
alter index emp_pk rebuild; 

删除索引

Sql代码  
  1. drop index emp_ename;
drop index emp_ename; 

如果索引中包含损坏的数据块,或者包含过多的存储碎片,需要首先删除这个索引,然后再重建它.
如果索引是在创建约束时由oracle自动产生的,可以通过禁用约束或删除约束的方法来删除对应的索引.
在删除一个表时,oracle会自动删除所有与该表相关的索引.

索引数据字典
all_indexes/dba_indexes/user_indexes 索引的基本信息
all_ind_columns/dba_ind_columns/user_ind_columns 索引对应的字段信息

转载于:https://www.cnblogs.com/shengel/archive/2011/03/20/1989588.html

oracle索引与约束(zhuang)相关推荐

  1. Oracle索引_约束

    用user_indexes和user_ind_columns系统表查看已经存在的索引 对于系统中已经存在的索引我们可以通过以下的两个系统视图(user_indexes和user_ind_columns ...

  2. 收集Oracle常用命令----索引及约束

    Oracle常用命令----索引 1.creating function-based indexes sql> create index summit.item_quantity on summ ...

  3. Oracle索引梳理系列(七)- Oracle唯一索引、普通索引及约束的关系

    版权声明:本文发布于http://www.cnblogs.com/yumiko/,版权由Yumiko_sunny所有,欢迎转载.转载时,请在文章明显位置注明原文链接.若在未经作者同意的情况下,将本文内 ...

  4. ORACLE的索引和约束详解数据库

    ORACLE的索引和约束详解数据库 Oracle的约束 * 如果某个约束只作用于单独的字段,即可以在字段级定义约束,也可以在表级定义约束,但如果某个约束作用于多个字段, 必须在表级定义约束 * 在定义 ...

  5. 如何获取Oracle数据库中某表及索引、约束、触发器、对象权限的创

    2019独角兽企业重金招聘Python工程师标准>>> 对于数据库中特定的某张表而言,又该如何获取建表语句.及索引.约束.外键约束.触发器.对象权限的创建脚本呢? OCM11g-&g ...

  6. Oracle表重命名后索引、约束、权限、同义词的影响

    create public synonym test01 for scott.test01; --同义词 create index scott.idx_col_date on scott.test01 ...

  7. Oracle 索引扫描的五种类型

    之前在讨论CBO和RBO的时候提到了索引扫描的几种类型. Oracle Optimizer CBO RBO http://blog.csdn.net/tianlesoftware/archive/20 ...

  8. Oracle索引扫描四大类的分析

    学习Oracle时,你可能会遇到Oracle索引扫描问题,这里将介绍Oracle索引扫描问题的解决方法,在这里拿出来和大家分享一下.根据索引的类型与where限制条件的不同,有4种类型的Oracle索 ...

  9. Oracle维护数据完整性——约束

    Oracle维护数据完整性--约束 维护数据的完整性--约束 约束用于确保数据库数据满足特定的规则.在oracle和sql server等数据库中,not null(非空).unique(唯一).pr ...

最新文章

  1. postgresql select for update 多行加锁顺序_insert into select加锁规则补充
  2. 他2年拿下博士学位,发表11篇顶会论文!浙大校友李旻辰斩获SIGGRAPH最佳博士论文奖...
  3. 如何在linux下安装mysql5.7?
  4. 2.什么是变量的数据类型
  5. jenkins 下载插件 一直失败_Jenkins 配置国内插件更新源
  6. java token_Java实现基于token认证的方法示例
  7. iPhone 13全系价格曝光:顶配售价将达新高
  8. 【2017级面向对象程序设计】作业二
  9. GoogLeNet 之 Inception v1 v2 v3 v4
  10. linux和unix的关系
  11. window10配置OpenGL ES3.0
  12. 国产宽带电力载波驱动芯片GS6212应用原理图(PIN TO PIN THS6212)
  13. 棋牌漏洞游戏反汇编译破解修改透视案例分析
  14. mysql 1556_mysqldump: Got error: 1556: You can't use locks with log tables
  15. PHP解析SOAP生成的xml
  16. 【虚幻引擎UE】UE5 超实用插件推荐
  17. 【新知实验室】——腾讯云TRTC实时音视频体验
  18. 视频合并软件怎么把多个视频合并为一个视频
  19. 企业发放的奖金根据利润提成。
  20. 英汉互译在线翻译器-大家都在用的英汉互译翻译器

热门文章

  1. FormatNumber函数
  2. 华为、中大、谷歌合作最新研究黑白漫画场景可批量上色
  3. AI近十年盘点:纵览AI发展历程,探寻AI未来走向
  4. 部署项目到云服务器上所遇到的困难
  5. 向虚拟机中传输文件的新解法——高效有用的邮箱传输
  6. 自动驾驶的“跃渊”时刻
  7. lazada发货_LAZADA开店——发货——收款流程,看这篇就够了
  8. Python中文件的读写操作
  9. 梯度下降、牛顿法凸优化、L1、L2正则化、softmax、Batchnorm、droupout、Targeted Dropout详解
  10. 模拟电路设计(19)---多谐波振荡器