Oracle 创建索引

上传人:油条 文档编号:20292621 上传时间:2017-11-21 格式:DOC 页数:2 大小:37KB
返回 下载 相关 举报
Oracle 创建索引_第1页
第1页 / 共2页
Oracle 创建索引_第2页
第2页 / 共2页
亲,该文档总共2页,全部预览完了,如果喜欢就下载吧!
资源描述

《Oracle 创建索引》由会员分享,可在线阅读,更多相关《Oracle 创建索引(2页珍藏版)》请在金锄头文库上搜索。

1、Oracle 创建索引Oracle 在创建索引时要遵循以下的原则: 平衡查询和 DML 的需要。在易挥发( DML 操作频繁)的表上尽量减少索引的数量,因为索引虽然加快了查询的速度,但却降低了 DML 操作速度。 将其放入单独的表空间,不要与表、临时段或还原(回滚)段放在一个表空间,因为索引段会与这些段竞争输入/输出(I/O) 。 使用统一的 EXTENT 尺寸:数据块尺寸的 5 倍,或表空间的 MINIMUM EXTENT 的尺寸。这样做的目的是为了减少系统的转换时间。 对大索引可以考虑使用 NOLOGGING。这样做的目的是通过减少 REDO 操作来提高系统的效率,但是如果一旦系统发生崩溃

2、,则该索引一般是无法进行完全灰度的。不过问题也不是很大,因为真正的数据还在表中,所以可以通过重建该索引来恢复与之前完全相同的效果。 索引的 INITRANS 参数通常应该比相对应表的高。以为索引项要比表中的数据行小的多,所以一个数据块可以存放更多的索引项(记录) 。创建索引的命令格式:CREATE (UNIQUE|BITMAP) INDEX 用户名.索引名ON 用户名 .表名(列名 ASC | DESC ,列名 ASC| DESC )TABLESPACE 表空间名PCTFREE 正整型数INITRANS 正整型数MAXTRANS 正整型数存储子句LOGGING | NOLOGGINGNOSOR

3、T其中, UNIQUE:说明该索引是唯一索引,默认是非唯一的 ASC:说明所创建的索引为升序 DESC:说明所创建的索引为降序 表空间名:说明将要创建的索引的表空间名 PCTFREE:在创建索引时每一个块中预留的空间 INITRANS:在每一个块中预分配的事物记录数,默认值为 2 MAXTRANS:在每一个块中可以分配的事物记录数的上限,默认为 255 存储子句:说明在索引中 EXTENTS 怎样分配 LOGGING:说明在创建索引是和以后的索引操作中要记录联机重做日志文件(默认) NOLOGGING:说明索引的创建和一些数据装入操作将不记录联机重做日志文件 NOSORT:数据库中所存的数据行

4、已经按升序排好,因此在创建索引时不需要再排序了 PCTUSED:在索引中不能说明该参数。因为索引记录必须以正确的顺序存放,所以用户不能控制何时向索引块中插入索引数据行使用数据字典的 dba_indexes 获取有关 scott 用户的索引基于表、所在的表空间、索引的类型和索引的状态等信息。SQL select index_name,table_name,tablespace_name,index_type, uniqueness,status from dba_indexeswhere owner = SCOTT AND INDEX_NAME not like SYS%INDEX_NAME T

5、ABLE_NAME TABLESPACE_NAME INDEX_TYPE UNIQUENES STATUS- - - - - -PK_DEPT DEPT USERS NORMAL UNIQUE VALIDPK_EMP EMP USERS NORMAL UNIQUE VALID使用数据字典 dba_ind_columns 获得 scott 用户的索引所基于表和列的等信息。SQLselect index_name,table_name,column_name,index_owner,table_owner2 from dba_ind_columns3* where table_owner = SC

6、OTT and index_name not like SYS%INDEX_NAME TABLE_NAME COLUMN_NAME INDEX_OWNER TABLE_OWNER- - - - -PK_EMP EMP EMPNO SCOTT SCOTTPK_DEPT DEPT DEPTNO SCOTT SCOTT创建索引:SQL CREATE INDEX scott.emp_ename_idx2 ON scott.emp(ename)3 PCTFREE 204 STORAGE(INITIAL 100K NEXT 100K5 PCTINCREASE 0 MAXEXTENTS 100)6* TAB

7、LESPACE PIONEER_INDEX索引已创建。SQL CREATE BITMAP INDEX scott.emp_job_idx2 ON scott.emp(job)3 PCTFREE 204 STORAGE(INITIAL 100K NEXT 100K5 PCTINCREASE 0 MAXEXTENTS 100)6 TABLESPACE PIONEER_INDEX;查看所创建的索引的存储参数是不是按着命令设置的:SQL select index_name,pct_free,pct_increase,initial_extent,next_extent2 from dba_indexes3 where owner = SCOTT AND INDEX_NAME not like SYS%;INDEX_NAME PCT_FREE PCT_INCREASE INITIAL_EXTENT NEXT_EXTENT- - - - -PK_DEPT 10 65536PK_EMP 10 65536EMP_ENAME_IDX 20 0 106496 1048576EMP_JOB_IDX 20 0 106496 1048576

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 行业资料 > 其它行业文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号