oracle索引对模糊查询,Oracle索引

一、Oracle索引原理

通俗易懂得讲,索引就是给每条记录建立了一个目录(索引),

每个建立的索引都是按照这个索引的字段去排序(实际未必是排序)存放,

然后按照索引字段去查询的时候,就先去查询索引,此时找到该条记录的页码rowid,然后再去主表中根据rowid查询到具体的数据。

组合索引是以多个列作为排序查询,组合索引中字段的先后有差别,单独查询第一个字段时,组合索引也能生效,但是单独查询后面的字段时,组合索引不生效。

位图索引是以二进制为存放,节省存放空间,查询更快,适合于性别、状态这类离散度比较低的字段

二、索引优缺点

优点:

当数据量大时,适当地建立索引能够大大地提高查询效率

缺点:

建立索引需要占用硬盘空间

索引会影响更新操作的效率,所以一个表的索引不是建越多越好

三、索引创建查看

创建索引

create index 索引名 on 表名(, , …) online

tablespace 表空间 ;

创建Bitmap索引

create bitmap index 索引名 on 表名(字段) online

tablespace 表空间 ;

删除索引

drop index 索引名;

查看该表的所有索引

select * from all_indexes where table_name = '表名';

查看该表的所有索引列

select* from all_ind_columns where table_name = '表名';

四、查看索引是否生效

生成查询计划

explain plan for

select * from t_call_records where t_bjhm='123456'

查看执行计划结果

select * from table(dbms_xplan.display)

1c44e7c48343e2f5f46948f0dd835c13.png

五、索引使用时的注意点

order by、group by使用索引的前提条件:

1.order by、group by中所有的列必须包含在相同的索引中并保持在索引中的排列顺序;

2.order by、group by中所有的列必须定义为非空

不走索引的几种情况:

1.where子句中使用 is null 和 is not null

2.where子句中使用函数

3.使用like ‘%T’ 进行模糊查询

4.where子句中使用不等于操作(包括:<>, !=, not colum >= ?, not colum <= ? ,可以使用or代替)

5.比较不匹配数据类型,例如:select * from tablewhere jlbh = 1;jlbh为varchar2类型字段

6.索引列上不要使用函数,如to_char、to_date等,如需频繁使用可以建立函数索引

7.用UNION替换OR(适用于索引列),对索引列使用OR将造成全表扫描

8.SELECT子句中避免使用()ORACLE在解析的过程中, 会将’’ 依次转换成所有的列名, 这个工作是通过查询数据字典完成的, 这意味着将耗费更多的时间

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值