设为首页 收藏本站
查看: 3745|回复: 0

[经验分享] oracle复习笔记之索引

[复制链接]

尚未签到

发表于 2018-9-14 09:05:19 | 显示全部楼层 |阅读模式
  http://123304258.blog.163.com/blog/static/123547020127204949494/
  http://blog.sina.com.cn/s/blog_608e20930100x74x.html
  sqlserver
  1.什么是索引:数据库中的索引是某个表中一列或多列值的集合和相应的指向表中物理标识这些值的数据页的逻辑指针清单。
  2.分类:
  唯一索引(UNIQUE):不允许两行具有相同的索引值(创建了唯一约束,系统将自动创建唯一索引)。
  主键索引:主键索引要求主键中的每个值是唯一的,(创建主键自动创建主键索引)。
  聚集索引(CLUSTERED):表中各行的物理顺序与键值的逻辑(索引)顺序相同,表中只能包含一个聚集索引,主键列默认为聚集索引。
  非聚集索引(NONCLUSTERED):表中各行的物理顺序与键值的逻辑(索引)顺序不匹配,表中可以有249个非聚集索引。
  3.创建索引的标准:用于频繁搜索的列;用于对数据进行排序的列。
  注意:如果表中仅有几行,或列中只包含几个不同的值,不推荐创建索引,因为SQLServer在小型表中用索引搜索数据所花的时间比逐行搜索更长。
  oracle
  
一、索引  索引和对应的表应该位于不同的表空间中(primarykey(id)usingindextablespacemytable_index),oracle能够并行读取位于不同硬盘上的数据,可以避免产生I/O冲突。
  B树索引:在B树的叶节点中存储索引字段的值与ROWID。唯一索引和不唯一索引都只是针对B树索引而言。Oracle最多允许包含32个字段的复合索引。
  1.索引的创建方法
  (1)*Tree索引
  Createindexindexnameontablename(columnname[columnname...])
  (2)反向索引
  Createindexindexnameontablename(columnname[columnname...])reverse
  (3)降序索引
  Createindexindexnameontablename(columnnameDESC[columnname...])
  (4)位图索引
  CreateBITMAPindexindexnameontablename(columnname[columnname...])
  (5)函数索引
  Createindexindexnameontablename(functionname(columnname))
  注意:创建索引后分析要索引才能起作用。
  analyzeindexindexnamecomputestatistics;
  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代码

  •   createindexemp_enameonemployees(ename)tablespaceusersstorage(......)pctfree0;
  创建唯一索引
Sql代码

  •   createuniqueindexemp_emailonemployees(email)tablespaceusers;
  创建位图索引
Sql代码

  •   createbitmapindexemp_sexonemployees(sex)tablespaceusers;
  创建反序索引
Sql代码

  •   createuniqueindexorder_reinxonorders(order_num,order_date)tablespaceusersreverse;
  创建函数索引(函数索引即可以是普通的B树索引,也可以是位图索引)
Sql代码

  •   createindexemp_substr_empnoonemployees(substr(empno,1,2))tablespaceusers;
  修改索引存储参数(与表类似,INITIAL和MINEXTENTS参数在索引建立以后不能再改变)
  alterindexemp_enamestorage(pctincrease50);
  由于定义约束时由oracle自动建立的索引通常是不知道名称的,对这类索引的修改经常是利用altertable..usingindex语句进行的,而不是alterindex语句
  利用下面的语句将employees表中primarykey约束对应的索引的PCTFREE参数修改为5
Sql代码

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

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

  •   alterindexemp_pkrebuild;
  6.删除索引
Sql代码

  •   dropindexemp_ename;
  如果索引中包含损坏的数据块,或者包含过多的存储碎片,需要首先删除这个索引,然后再重建它.
  如果索引是在创建约束时由oracle自动产生的,可以通过禁用约束或删除约束的方法来删除对应的索引.
  在删除一个表时,oracle会自动删除所有与该表相关的索引.
  7.索引数据字典
  all_indexes/dba_indexes/user_indexes索引的基本信息
  all_ind_columns/dba_ind_columns/user_ind_columns索引对应的字段信息
  


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-581873-1-1.html 上篇帖子: oracle 日常操作 下篇帖子: oracle复习笔记之TRUNC
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表