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

1.索引的创建方法 
(1)*Tree索引 
Create index indexname on tablename(columnname[columnname...]) 
(2)反向索引 
Create index indexname on tablename(columnname[columnname...]) reverse 
(3)降序索引 
Create index indexname on tablename(columnname DESC[columnname...]) 
(4)位图索引 
Create BITMAP index indexname on tablename(columnname[columnname...]) 
(5)函数索引 
Create index indexname on tablename(functionname(columnname))

注意:创建索引后分析要索引才能起作用。 
analyze index indexname compute statistics;

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

3.索引使用场合及建议 
(1)B*Tree索引 
    常规索引,多用于oltp系统,快速定位行,应建立于高cardinality列(即列的唯一值除以行数为一个很大的值,存在很少的相同值)。 
(2)反向索引 
B*Tree的衍生产物,应用于特殊场合,在ops环境加序列增加的列上建立,不适合做区域扫描。 
(3)降序索引 
B*Tree的衍生产物,应用于有降序排列的搜索语句中,索引中储存了降序排列的索引码,提供了快速的降序搜索。 
(4)位图索引 
位图方式管理的索引,适用于OLAP(在线分析)和DSS(决策处理)系统,应建立于低cardinality列,适合集中读取,不适合插入和修改,提供比B*Tree索引更节省的空间。 
(5)函数索引 
B*Tree的衍生产物,应用于查询语句条件列上包含函数的情况,索引中储存了经过函数计算的索引码值。可以在不修改应用程序的基础上能提高查询效率。

4.索引例 
创建不唯一索引

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

创建唯一索引

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

创建位图索引

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

创建反序索引

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

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

Sql代码  
  1. 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

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

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

Sql代码  
  1. alter index emp_pk coalesce;

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

Sql代码  
  1. alter index emp_pk rebuild;

6.删除索引

Sql代码  
  1. drop index emp_ename;

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

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

二、序列(Sequence) 
序列是一数据库对象,利用它可生成唯一的整数。一般使用序列自动地生成主键值。 
(1) 建立序列命令 
CREATE SEQUENCE [user.]sequence_name 
[increment by n] 
[start with n] 
[maxvalue n | nomaxvalue] 
[minvalue n | nominvalue]; 
[NOCYCLE]  -- 
INCREMENT BY: 指定序列号之间的间隔,该值可为正的或负的整数,但不可为0。序列为升序。忽略该子句时,缺省值为1。 
START WITH:指定生成的第一个序列号。在升序时,序列可从比最小值大的值开始,缺省值为序列的最小值。对于降序,序列可由比最大值小的值开始,缺省值为序列的最大值。 
MAXVALUE:指定序列可生成的最大值。 
NOMAXVALUE:为升序指定最大值为1027,为降序指定最大值为-1。 
MINVALUE:指定序列的最小值。 
NOMINVALUE:为升序指定最小值为1。为降序指定最小值为-1026。 
NOCYCLE:一直累加,不循环 
(2)更改序列命令 
ALTERSEQUENCE [user.]sequence_name 
[INCREMENT BY n] 
[MAXVALUE n| NOMAXVALUE ] 
[MINVALUE n | NOMINVALUE]; 
修改序列可以: 
    修改未来序列值的增量。 
    设置或撤消最小值或最大值。 
    改变缓冲序列的数目。 
    指定序列号是否是有序。

(3)删除序列命令 
DROP SEQUENCE [user.]sequence_name; 
用于从数据库中删除一序列。 
例子:

Sql代码  
  1. create sequence NCME_QUESTION_SEQ
  2. minvalue 1 maxvalue 999999999999 start with 1 increment by 1 nocache;

oracle索引与序列相关推荐

  1. Oracle数据库之对象视图、索引、序列、同义词

    Oracle数据库总结: Oracle数据库之集合运算 Oracle数据库之数据处理 Oracle数据库之建表和管理表 Oracle数据库之对象视图.索引.序列.同义词 视图: 语法: create ...

  2. oracle 删除表 索引也会删除吗,Oracle 删除当前用户下所有的表、索引、序列

    通过下面语句可以得到要删除Oracle的所有表.索引.序列... 的语句 select 'drop table ' || table_name ||';'||chr(13)||chr(10) from ...

  3. oracle 视图、索引、序列、同义词

    目录 1.视图对象 1.1创建视图 1)简单视图 2)建立只读视图 3)复杂视图 1.2管理视图 1)查看视图定义 2)修改视图定义 3)重新编译视图 4)删除视图 2.索引 2.1索引概述 2.2创 ...

  4. mysql oracle创建视图索引吗_Oracle视图,索引,序列

    什么是视图[View] (1)视图是一种虚表 (2)视图建立在已有表的基础上, 视图赖以建立的这些表称为基表 (3)向视图提供数据内容的语句为 SELECT 语句,可以将视图理解为存储起来的 SELE ...

  5. [转载]oracle索引的简单总结

    原文地址:oracle索引的简单总结作者:kindle 一.索引的概念: 数据库的索引类似于书籍的索引.在书籍中,索引允许用户不必翻阅完整个书就能迅速地找到所需要的信息.在数据库中,索引也允许数据库程 ...

  6. Oracle索引扫描方式

    文章目录 0.参考资料 1.索引扫描方式和索引类型概述 2.索引唯一扫描(index unique scan) 3.索引范围扫描(index range scan) 4.索引跳跃扫描(index sk ...

  7. Oracle索引梳理系列(八)- 索引扫描类型及分析(高效索引必备知识)

    理解oracle索引扫描类型的特点以及具体触发的条件,对于通过合理地使用索引,进行sql优化至关重要(例如组合索引的引导列的选择问题). 在总结索引扫描类型前,需要再次强调关于索引特点的几个关键点: ...

  8. oracle查看表空间的序号,Oracle查询所有序列

    --查看当前用户的所有序列 select SEQUENCE_OWNER,SEQUENCE_NAME from dba_sequences where sequence_owner='用户名'; --查 ...

  9. oracle怎么么创建索引,Oracle 创建索引,oracle索引怎么创建

    Oracle 创建索引,oracle索引怎么创建 索引是数据库服务器用来加快检索的速度,再通过加了索引的列进行检索 时候,数据库会自动使用索引,使用索引所在的列值进行快速检索,快速定位到 真实的数据内 ...

最新文章

  1. java 下载文件功能代码例子
  2. 障碍物规避算法的MATLAB仿真
  3. Android 大牛开发者博客列表
  4. 小牛带你nginx反向代理中神奇的斜线
  5. C++ 重载运算符 继承 多态 (超详细)
  6. [Redis6]Redis启动_前台启动和后台启动
  7. java 系统自动检测_如何在Java中检测OS(操作系统)名称?
  8. 基于 PostgreSQL 的 EMQ X Auth ACL
  9. python斜率转换为航向0-360_机器学习模型之LinearRegression(Python学习笔记)
  10. 工作中使用BBM:消费者的“闺蜜”级顾问 凯特周智囊团
  11. 深蓝超级计算机象棋人机大战,象棋人机大战绝唱:超级计算机“浪潮天梭”vs“象棋第一人”许银川的巅峰之战...
  12. matlab中abs函数,matlab 中的abs函数什么意思 编程知识
  13. Boom 3D全新2022版音频增强应用程序App
  14. obs linux编译,教你如何在 Ubuntu 18.04/16.04 中安装 OBS Studio 21.1
  15. MySQL表查询关键字
  16. tabIndex的用途
  17. 请求转发和重定向的区别及什么时候使用
  18. 山武阀门配件AVP300-RSD3A
  19. win7如何评价计算机,一个90后眼中的Windows系列计算机系统
  20. MATLAB实现多目标粒子群算法

热门文章

  1. 银行总行vs分行的薪资待遇、报考要求等不同
  2. [微云助手/微小云怎么用]如何设置新人欢迎语
  3. 这个技术的出现,可能会颠覆阿里云、AWS!
  4. 浅析人体检测技术及应用场景
  5. 等待事件系列(1)--User I/O类型
  6. html微信支付功能代码,H5调起微信支付功能(示例代码)
  7. 手把手教你如何购买腾讯云服务器(图文教程)?
  8. .net html转为pdf,Aspose.PDF for .NET功能解读:如何在桌面和Web应用中将HTML转换为PDF...
  9. Spring Cloud学习笔记【十二】Hystrix的使用和了解
  10. leetcode--50--Pow(x, n)