http://123304258.blog.163.com/blog/static/123547020127204949494/
sqlserver
1.什么是索引:数据库中的索引是某个表中一列或多列值的集合和相应的指向表中物理标识这些值的数据页的逻辑指针清单。
2.分类:
唯一索引(UNIQUE):不允许两行具有相同的索引值(创建了唯一约束,系统将自动创建唯一索引)。
主键索引:主键索引要求主键中的每个值是唯一的,(创建主键自动创建主键索引)。
聚集索引(CLUSTERED):表中各行的物理顺序与键值的逻辑(索引)顺序相同,表中只能包含一个聚集索引,主键列默认为聚集索引。
非聚集索引(NONCLUSTERED):表中各行的物理顺序与键值的逻辑(索引)顺序不匹配,表中可以有249个非聚集索引。
3.创建索引的标准:用于频繁搜索的列;用于对数据进行排序的列。
注意:如果表中仅有几行,或列中只包含几个不同的值,不推荐创建索引,因为SQLServer在小型表中用索引搜索数据所花的时间比逐行搜索更长。
oracle
createindexemp_enameonemployees(ename)tablespaceusersstorage(......)pctfree0;
创建唯一索引
createuniqueindexemp_emailonemployees(email)tablespaceusers;
创建位图索引
createbitmapindexemp_sexonemployees(sex)tablespaceusers;
创建反序索引
createuniqueindexorder_reinxonorders(order_num,order_date)tablespaceusersreverse;
创建函数索引(函数索引即可以是普通的B树索引,也可以是位图索引)
createindexemp_substr_empnoonemployees(substr(empno,1,2))tablespaceusers;
修改索引存储参数(与表类似,INITIAL和MINEXTENTS参数在索引建立以后不能再改变)
alterindexemp_enamestorage(pctincrease50);由于定义约束时由oracle自动建立的索引通常是不知道名称的,对这类索引的修改经常是利用altertable..usingindex语句进行的,而不是alterindex语句利用下面的语句将employees表中primarykey约束对应的索引的PCTFREE参数修改为5altertableemployeesenableprimarykeyusingindexpctfree5;
5.清理索引碎片
(1).合并索引(只是简单的将B树叶结点中的存储碎片合并在一起,并不会改变索引的物理组织结构)alterindexemp_pkcoalesce;
(2).重建索引(不仅能够消除存储碎片,还可以改变索引的全部存储参数设置,并且可以将索引移动到其它的表空间中,重建索引
实际上就是再指定的表空间中重新建立一个新的索引,然后删除原来的索引)alterindexemp_pkrebuild;
6.删除索引
dropindexemp_ename;
如果索引中包含损坏的数据块,或者包含过多的存储碎片,需要首先删除这个索引,然后再重建它.
如果索引是在创建约束时由oracle自动产生的,可以通过禁用约束或删除约束的方法来删除对应的索引.在删除一个表时,oracle会自动删除所有与该表相关的索引.7.索引数据字典all_indexes/dba_indexes/user_indexes索引的基本信息all_ind_columns/dba_ind_columns/user_ind_columns索引对应的字段信息