Oracle 执行计划(二)------表访问的几种方式

表访问的几种方式:(非全部)

参照表

primary key is id

1.TABLE ACCESS FULL(全表扫描):查询出该表所有数据,获取的数据执行where语句。

Don’t create any index

no relation With primary key

 

2.TABLE ACCESS BY ROWID(通过ROWID的表存取):通过ROWID获取表数据

Don’t create any index

Primary key column is id

 

3.TABLE ACCESS BY INDEX SCAN(索引扫描)

 

 

 

索引扫描又分五种:

1.INDEX UNIQUE SCAN(索引唯一扫描):查询条件中包含主键,因为主键是有唯一性约束的特殊索引

Don’t create any index

Primary key column is id

 

 

2.INDEX RANGE SCAN(索引范围扫描)

Have index: create index user_msg_test_index on qcb_user_msg_test (address,phonenumber)

  • 在唯一索引列上使用了范围操作符(如:>   <   <>   >=   <=   between)
  •          select * from qcb_user_msg_test where id >2
  • 在组合索引上,只使用部分列进行查询(查询时必须包含前导列,否则会走全表扫描)
  •         
  • 对非唯一索引列上进行的任何查询

 

 

3.INDEX FULL SCAN(索引全扫描)

进行全索引扫描时,查询出的数据都必须从索引中可以直接得到,且查询条件不包含索引前导列

 create index user_msg_test_index on qcb_user_msg_test (sex,address,phonenumber)

 

 

 

4.INDEX FAST FULL SCAN(索引快速扫描)

扫描索引中的所有的数据块,与 INDEX FULL SCAN 类似,但是一个显著的区别是它不对查询出的数据进行排序(即数据不是以排序顺序被返回)

 

5.INDEX SKIP SCAN(索引跳跃扫描)

 

转载于:https://www.cnblogs.com/zhougongjin/p/10711359.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值