oracle中索引的使用

1.索引应用于大数据量的数据表时,将很大程度上提高查询性能。使用索引可以提高数据库的性能。

2.若未建立索引,执行搜索时会执行全表搜索;

一旦索引创建,那么表中所有数据将按照字母表顺序进行分块处理,执行搜索时,会进行分块搜索,从而加快查询速度。

3.创建索引的语法

[color=red]create index idx_emp_ename on emp(ename);[/color]


4.索引的使用时机??

(1)[color=red]小数据量的表不宜使用索引[/color]

小数据量的表,首先要创建索引,并寻找数据块,然后才进行数据的实

际检索,因此对于小数据量的表,使用全表搜索往往会快于使用索引。

(2)[color=red]频繁使用插入、修改、删除等DML操作的数据表不宜使用索引[/color]

针对表的插入、修改、删除等操作非常频繁时,将会降低数据库的

性能。因为每次的动作都可能会触发两倍甚至两倍以上的成本来完成索

引操作。(如果在表上建立了索引,向表中插入数据时,数据库会重新组

织索引,此时数据库除了正常的插入操作之外,还需为新记录添加索引项

,而索引已有数据块无法满足存储要求,因此,数据库将为其分配新的

存储空间。)(修改数据时,原数据的索引项被打上了删除标记,然后添

加新数据的索引项)(删除数据时,相应的索引项只是被打上了删除标记)


5.索引使用中的误区??

[color=darkred](1)使用比较运算符不当[/color]

oracle是通过比较索引值来实现搜索的,但是,如果使用了不当的比较

运算符,有可能仍会使用全表扫描。使用不等于的话,oracle会比较所有

记录。

如:select * from emp where ename<>'PEOPLE';

[color=darkred](2)函数的使用[/color]

对于索引列,一旦使用了函数,那么将在查询是无法使用索引。

如: select * from emp where instr(ename,'_')=0;

[color=darkred](3)联合索引[/color]

索引不仅可以建立在单列之上,也可以建立在多列之上

建立联合索引语句:
create index idx_ename_sal_deptno on emp(ename,sal,deptno)

只有当查询条件中包含联合索引的前导列(即联合索引第一列)时,才能发
挥联合索引带来的查询性能的提高。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
信息数据从传统到当代,是一直在变革当,突如其来的互联网让传统的信息管理看到了革命性的曙光,因为传统信息管理从时效性,还是安全性,还是可操作性等各个方面来讲,遇到了互联网时代才发现能补上自古以来的短板,有效的提升管理的效率和业务水平。传统的管理模式,时间越久管理的内容越多,也需要更多的人来对数据进行整理,并且数据的汇总查询方面效率也是极其的低下,并且数据安全方面永远不会保证安全性能。结合数据内容管理的种种缺点,在互联网时代都可以得到有效的补充。结合先进的互联网技术,开发符合需求的软件,让数据内容管理不管是从录入的及时性,查看的及时性还是汇总分析的及时性,都能让正确率达到最高,管理更加的科学和便捷。本次开发的医院后台管理系统实现了病房管理、病例管理、处方管理、字典管理、公告信息管理、患者管理、药品管理、医生管理、预约医生管理、住院管理、管理员管理等功能。系统用到了关系型数据库王者MySql作为系统的数据库,有效的对数据进行安全的存储,有效的备份,对数据可靠性方面得到了保证。并且程序也具备程序需求的所有功能,使得操作性还是安全性都大大提高,让医院后台管理系统更能从理念走到现实,确确实实的让人们提升信息处理效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值