oralce 索引
来源:互联网 发布:怎么看网络计划图 编辑:程序博客网 时间:2024/06/08 13:46
--查看失效索引
SELECT A.INDEX_NAME, A.TABLE_NAME, A.TABLE_OWNER, A.*
FROM DBA_INDEXES A
WHERE upper(A.STATUS) = 'UNUSABLE';
--查看索引状态
SELECT A.INDEX_NAME,a.status,A.TABLE_NAME, A.TABLE_OWNER, A.*
FROM DBA_INDEXES A
WHERE upper(a.index_name) in (upper('IDX_ORDER_SALE_RES_CODE'),
upper('IDX_ORDER_SALE_RES_DEALER_ID'),
upper('IDX_ORDER_SALE_RES_ORDER_NO'),
upper('IDX_ORDER_SALE_RES_STOCK_NO'));
--你可以把表删了,在创建没主键约束的表就可以了;或者是你创建约束时指定约束名
--例:
create table t_stu(stuid integer not null,stuname varchar(50))
--添加主键
alter table t_stu add constraint p_pk priary key stuid;--p_pk是约束名字
--删除主键:
alter table t_stu drop constraint p_pk;--drop 索引。
--建分区索引
create index IDX_TEMP_test on test (test_ID)local;
--建全局索引 可以指定表空间
create index IDX_TEMP_test on test (test_ID);
--查看一个表的索引信息,partion为空则是全局索引
SELECT a.owner,a.segment_name,a.segment_type,a.partition_name, a.tablespace_name,a.bytes,b.table_name
FROM dba_segments a,
Dba_Indexes b
WHERE a.owner = b.owner
AND a.segment_name = b.index_name
AND b.table_name = 'CH_SYS_FILEACHIEVE'
ORDER BY a.segment_name,a.partition_name;
--查看分区索引状态
select index_name, partition_name, status
from user_ind_partitions
where index_name in ('IDX_SUBS_TOTALFEE_MSISDN','IDX_SUBS_IMEI_MSISDN','IDX_SUBS_CHARGEALL_MSISDN');
--重建索引
alter index U_IDX_UVC_PSMENT04 rebuild online nologging;
局部索引local index
1. 局部索引一定是分区索引,分区键等同于表的分区键,分区数等同于表的分区说,一句话,局部索引的分区机制和表的分区机制一样。
2. 如果局部索引的索引列以分区键开头,则称为前缀局部索引。
3. 如果局部索引的列不是以分区键开头,或者不包含分区键列,则称为非前缀索引。
4. 前缀和非前缀索引都可以支持索引分区消除,前提是查询的条件中包含索引分区键。
5. 局部索引只支持分区内的唯一性,无法支持表上的唯一性,因此如果要用局部索引去给表做唯一性约束,则约束中必须要包括分区键列。
6. 局部分区索引是对单个分区的,每个分区索引只指向一个表分区,全局索引则不然,一个分区索引能指向n个表分区,同时,一个表分区,也可能指向n个索引分区,
对分区表中的某个分区做truncate或者move,shrink等,可能会影响到n个全局索引分区,正因为这点,局部分区索引具有更高的可用性。
7. 位图索引只能为局部分区索引。
8. 局部索引多应用于数据仓库环境中。
全局索引global index
1. 全局索引的分区键和分区数和表的分区键和分区数可能都不相同,表和全局索引的分区机制不一样。
2. 全局索引可以分区,也可以是不分区索引,全局索引必须是前缀索引,即全局索引的索引列必须是以索引分区键作为其前几列。
3. 全局分区索引的索引条目可能指向若干个分区,因此,对于全局分区索引,即使只动,截断一个分区中的数据,都需要rebulid若干个分区甚
至是整个索引。
4. 全局索引多应用于oltp系统中。
5. 全局分区索引只按范围或者散列hash分区,hash分区是10g以后才支持。
6. oracle9i以后对分区表做move或者truncate的时可以用update global indexes语句来同步更新全局分区索引,用消耗一定资源来换取高度的可用性。
7. 表用a列作分区,索引用b做局部分区索引,若where条件中用b来查询,那么oracle会扫描所有的表和索引的分区,成本会比分区更高,此时可以考虑用b做全局分区索引
- oralce 索引
- Oralce 索引
- oralce索引
- [Oralce] 分区表和索引
- oralce 索引概述
- oralce索引学习
- oralce数据库索引
- oralce 索引命名规范
- 建立ORALCE空间索引相关
- Oralce如何选择合适的索引类型
- oralce
- oralce
- oralce
- oralce &
- ORALCE 创建主键&唯一约束同时也创建索引
- oralce索引组织表与聚簇表的区别
- oralce 提高查询效率 给条件字段添加索引 sql
- oralce,分区、子分区、分区索引,分区索引数据查询sql
- AndroiJNI开发入门篇
- Android中Context详解 ---- 你所不知道的Context
- 删除重复列(注:表的ID数据类型是uniqueidentifier)
- android 动态菜单组件
- SQL Server ——表
- oralce 索引
- 关于释放对象以后为什么要=nil
- poj 2797 最短前缀
- hibernate的or查询
- sysfs 驱动
- assertThat详解
- 在Delphi 2010中安装ShellTreeView等控件
- 防止表单重复提交的几种方法
- 读取properties文件, 比如获得税率,提示等信息