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

[经验分享] Oracle系列:(25)索引

[复制链接]

尚未签到

发表于 2018-9-7 12:50:41 | 显示全部楼层 |阅读模式
  什么是索引【Index】
  (1)是一种快速查询表中内容的机制,类似于新华字典的目录
  (2)运用在表中某个/些字段上,但存储时,独立于表之外
  为什么要用索引
  (1)通过指针加速Oracle服务器的查询速度
  (2)通过rowid快速定位数据的方法,减少磁盘I/O
  rowid是oracle中唯一确定每张表不同记录的唯一身份证
  rowid的特点
  (1)位于每个表中,但表面上看不见,例如:desc emp是看不见的
  (2)只有在select中,显式写出rowid,方可看见
  (3)它与每个表绑定在一起,表亡,该表的rowid亡,二张表rownum可以相同,但rowid必须是唯一的
  (4)rowid是18位大小写加数字混杂体,唯一表代该条记录在DBF文件中的位置
  (5)rowid可以参与=/like比较时,用''单引号将rowid的值包起来,且区分大小写
  (6)rowid是联系表与DBF文件的桥梁
DSC0000.jpg

  思考:rowid是联系表与DBF文件的桥梁,我不理解。
  索引的特点
  (1)索引一旦建立, Oracle管理系统会对其进行自动维护, 而且由Oracle管理系统决定何时使用索引
  (2)用户不用在查询语句中指定使用哪个索引
  (3)在定义primary key或unique约束后系统自动在相应的列上创建索引
  (4)用户也能按自己的需求,对指定单个字段或多个字段,添加索引
  什么时候【要】创建索引
  (1)表经常进行 SELECT 操作
  (2)表很大(记录超多),记录内容分布范围很广
  (3)列名经常在 WHERE 子句或连接条件中出现
  注意:符合上述某一条要求,都可创建索引,创建索引是一个优化问题,同样也是一个策略问题
  什么时候【不要】创建索引
  (1)表经常进行 INSERT/UPDATE/DELETE 操作
  (2)表很小(记录超少)
  (3)列名不经常作为连接条件或出现在 WHERE 子句中
  同上注意
  为emp表的empno单个字段,创建索引emp_empno_idx,叫单列索引,create index 索引名 on 表名(字段,...)
create index emp_empno_idx  
on emp(empno);
DSC0001.jpg

  为emp表的ename,job多个字段,创建索引emp_ename_job_idx,多列索引/联合索引
create index emp_ename_job_idx  
on emp(ename,job);
  如果在where中只出现job不使用索引
  如果在where中只出现ename使用索引
  我们提倡同时出现ename和job
  注意:索引创建后,只有查询表有关,和其它(insert/update/delete)无关,解决速度问题
  删除emp_empno_idx和emp_ename_job_idx索引,drop index 索引名
drop index emp_empno_idx;  
drop index emp_ename_job_idx;
DSC0002.jpg




运维网声明 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-566112-1-1.html 上篇帖子: Oracle系列:(24)序列 下篇帖子: Oracle全库导入表报错 ORA-39126
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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