count(*)快还是count(列)快

一、没建索引一样快

create table t as select * from dba_objects;
update t set object_id =rownum ;

 

此时没建索引,因此他们是一样快。

select count(*) from t;
select count(object_id) from t;

二、为列object_id创建索引

create index idx_object_id on t(object_id);

此时count(object_id)比count(*)快很多

 

三、修改列object_id,设置不允许为空

alter table T modify object_id  not  null;

此时count(object_id)和count(*)一样快。

 

四、最佳字段顺序(越往后的列访问CPU开销大)

给我们开发员的启示就是:把最常用的列建在最前面。不常用的列建在后面。

优化器是这么搞的:列的偏移量决定性能,列越靠后,访问的开销越大。由于count(*)的算法与列偏移量无关,所以count(*)最快。

 

转载于:https://www.cnblogs.com/fjzsl/p/9291942.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值