博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Oracle count()函数
阅读量:6403 次
发布时间:2019-06-23

本文共 1310 字,大约阅读时间需要 4 分钟。

count(1)与count(*)比较:

如果你的数据表没有主键,那么count(1)比count(*)快 

如果有主键的话,那主键(联合主键)作为count的条件也比count(*)要快 
如果你的表只有一个字段的话那count(*)就是最快的啦 
count(*) count(1) 两者比较。主要还是要count(1)所相对应的数据字段。 
如果count(1)是聚索引,id,那肯定是count(1)快。但是差的很小的。 
因为count(*),自动会优化指定到那一个字段。所以没必要去count(?),用count(*),sql会帮你完成优化的

count详解:

count(*)将返回表格中所有存在的行的总数包括值为null的行,然而count(列名)将返回表格中除去null以外的所有行的总数.

distinct+ 列名,得到的结果将是除去值为null和重复数据后的结果

----------------------------------------------------------------------------------------------------------------

举例演示如下:

SQL> create table test
  2  (
  3  ename varchar2(10),
  4  sal number(4)
  5  );

表已创建。

SQL> insert into test values('fxe1',90);

已创建 1 行。

SQL> insert into test(ename) values('fxe2');

已创建 1 行。

SQL> insert into test(ename) values('fxe3');

已创建 1 行。

SQL> insert into test(ename) values('fxe4');

已创建 1 行。

SQL> insert into test values('fxe5',80);

已创建 1 行。

SQL> insert into test values('fxe6',80);

已创建 1 行。

SQL> select * from test;

ENAME             SAL                                                           

---------- ----------                                                           
fxe1               90                                                           
fxe2                                                                            
fxe3                                                                            
fxe4                                                                            
fxe5               80  

fxe6               80                                                        

SQL> select count(*) from test;

  COUNT(*)                                                                      

----------                                                                      
         6                                                                     

SQL> select count(sal) from test;

COUNT(SAL)                                                                      

----------                                                                      
         3                                                                     

SQL> select count(distinct sal) from test;

COUNT(DISTINCTSAL)                                                              

------------------                                                              
                 2                                                             

SQL> select distinct sal from test;

       SAL

----------
        80
        90

转载于:https://www.cnblogs.com/zjhnl/archive/2011/11/29/2267037.html

你可能感兴趣的文章
AgileEAS.NET之数据关系映射ORM
查看>>
Jquery封装tab自动切换效果
查看>>
Iperf安装使用及测试专线带宽
查看>>
抢先体验IE9
查看>>
【斗医】【16】Web应用开发20天
查看>>
javascript 基本使用—字符串、变量、数组、函数、for循环
查看>>
[C# 开发技巧]实现属于自己的截图工具
查看>>
mysql基础调优
查看>>
CYQ.Data 快速开发之UI(赋值、取值、绑定)原理
查看>>
使用路由器实现不同VLAN间通信_路由交换
查看>>
真我新格调 勇敢使梦想触手可及
查看>>
ExtJs 动态RadioGroup的子项 [ Ext | RadioGroup | items ]
查看>>
idea模板注释
查看>>
DHCP服务介绍
查看>>
Hibernate的数据删除,更改
查看>>
编程学习初体验(5. 如何自学编程)(2)
查看>>
思科ISR G1与ISR G1C的区别
查看>>
利用perl提取web配置文件中的域名对应的路径
查看>>
VMware虚拟化---集群高可用纵览
查看>>
Centos5上安装JRE和LUMAQQ
查看>>