- 浏览: 208518 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
strong8808:
activemq5.8.0 客户端,服务端启动序列图 -
xurichusheng:
第一题,如果使用 not exists 的话,可以改成:SEL ...
SQL笔试题 -
dingjun1:
cuisuqiang 写道如何解决呢?我的是对了也照样缓存增加 ...
事务未正确关闭引起的HIBERNATE SESSION不能正确关闭 -
dingjun1:
aijezdm915 写道lz ,我也是在写项目描述是犯愁,能 ...
如果在简历中描述项目 -
aijezdm915:
lz ,我也是在写项目描述是犯愁,能否给个你的简历demo,我 ...
如果在简历中描述项目
转载:http://log-cd.iteye.com/blog/314661
oracle索引与序列
关键字: oracle index
一、索引
索引和对应的表应该位于不同的表空间中(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;
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 reverse;
create unique index order_reinx on orders(order_num,order_date)
tablespace users reverse;
创建函数索引(函数索引即可以是普通的B树索引,也可以是位图索引)
Sql代码
1. create index emp_substr_empno on employees(substr(empno,1,2)) tablespace users;
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;
alter table employees enable primary key using index pctfree 5;
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;
6.删除索引
Sql代码
1. drop index emp_ename;
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索引与序列
关键字: oracle index
一、索引
索引和对应的表应该位于不同的表空间中(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;
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 reverse;
create unique index order_reinx on orders(order_num,order_date)
tablespace users reverse;
创建函数索引(函数索引即可以是普通的B树索引,也可以是位图索引)
Sql代码
1. create index emp_substr_empno on employees(substr(empno,1,2)) tablespace users;
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;
alter table employees enable primary key using index pctfree 5;
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;
6.删除索引
Sql代码
1. drop index emp_ename;
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;
发表评论
-
tomcat配置数据源(转载)
2012-02-23 10:57 913转载:http://www.douban.com/note/7 ... -
行连接检测(待整理 )
2010-12-17 10:54 1278网上搜集的,待整理 pctused(percent used ... -
在Oracle 9i下的display_cursor脚本
2010-12-08 13:37 1222转载:http://www.laoxiong.net/orac ... -
事务级别及相关内容
2010-09-19 20:18 840事务的四个属性:原子 ... -
ORACLE 内存结构 事件相关 statspack
2010-09-05 16:16 1253基本的内存结构包括:System Global Area SG ... -
ORA-12560及修改sys密码
2010-09-01 10:44 2088修改了,tnsnames.ora listener.ora中的 ... -
数据库设计经验谈(转)
2010-07-27 22:07 841一个成功的管理系统,是由:[50% 的业务 + 50% 的软件 ... -
Oracle 数据类型及存储方式
2010-07-13 08:29 1028http://www.iteye.com/topic/2207 ... -
ORACLE 10 JDBC SQL跟踪示例
2010-07-04 12:55 1728ORACLE 10 JDBC SQL跟踪示例 1、查询v$pa ... -
not in null 与null运算
2010-04-23 12:09 1608Not in \ in中包含有null值的列,不会排除null ... -
触发器
2010-04-15 16:41 42select * from user_trig ... -
inner join left join right join on where
2010-03-31 18:49 1848理解 inner join 和 outer join inne ... -
理解ORACLE字符集
2010-03-23 19:08 1094转载:http://silverw0396.iteye.com ... -
isqlplus不能正常访问的问题
2010-03-19 13:02 1069rhel5.2 oracle 10.0.2.0.1.0 1、 ... -
red hat enterprise linux 5.2 install and startup oracle 10.2.0
2010-03-17 21:04 1680d rhel5.2下安装ORACLE 10G 我的安装步骤参考 ... -
PreparedStatement.setObject(int i,Object obj) 无效的列类型
2009-10-26 17:21 4902当往下面的方法传递参数时,传入了java.util.Date类 ... -
ORA-01791: 不是 SELECTed 表达式
2009-10-26 16:50 2327ORA-01791: 不是 SELECTed 表达式,这报错莫 ... -
ORACLE SQL基础知识
2009-04-15 18:41 2050问:什么是NULL? 答:在我们不知道具体有什么数据的时候,也 ... -
ORACLE TEXT全文检索
2008-10-07 18:23 2283ORACLE 版本10.0.2 查看数据库相关的信息selec ... -
SQL笔试题
2008-07-15 15:12 39401.用一条SQL语句 查询出 ...
相关推荐
oracle索引,常见索引问题,详见PPT内容
Oracle 索引 使用方法,索引 使用原理, 索引 使用顺序过程
oracle 索引的原理原理深入理解!
oracle索引类型及扫描方式大整理new
ORACLE索引详解及SQL优化,详细描述了几种常用索引原理以及创建方法,解读索引生效条件,以及在开发中常用的提高数据库效率、降低数据库资源消耗的方法。
oracle索引失效的总结
详细介绍了一些oracle索引被限制的一些情况
Oracle索引优化。Oracle索引优化。Oracle索引优化
Oracle索引的监控.pdfOracle索引的监控.pdfOracle索引的监控.pdfOracle索引的监控.pdf
oracle的索引,非常适合初学者,介绍索引的分类,如何创建,修改等
Oracle优化全攻略一【Oracle 索引概念】.docx
ORACLE 索引技术
oracle索引大全,包括所有的建立oracle索引的方法,不会的就来看看吧
oracle索引唯一一本经典的书,讲述索引类型,索引设计。英文原版~~~
oracle各种索引的区别与使用,由浅入深
Oracle数据库索引机制分析,内容很详细
Oracle索引的创建、简介、技巧,希望可以给学习Oracle的人带来帮助!
oracle索引与分区索引介绍 删除分区 分区合并(从中间删除掉一个分区,或者两个分区需要合并后减少分区数量) 创建新的分区 交换分区
Oracle数据库经典优化之索引原理篇 Oracle中建立索引并强制优化器 基于索引的SQL语句优化之降龙十八掌 30个Oracle语句优化规则详解-性能调优