count()与count(*)比较:   

    如果你的数据表没有主键,那么count()比count(*)快
如果有主键的话,那主键(联合主键)作为count的条件也比count(*)要快
如果你的表只有一个字段的话那count(*)就是最快的啦
count(*) count() 两者比较。主要还是要count()所相对应的数据字段。
如果count()是聚索引,id,那肯定是count()快。但是差的很小的。
因为count(*),自动会优化指定到那一个字段。所以没必要去count(?),用count(*),sql会帮你完成优化的 count详解: count(*)将返回表格中所有存在的行的总数包括值为null的行,然而count(列名)将返回表格中除去null以外的所有行的总数(有默认值的列也会被计入).
distinct 列名,得到的结果将是除去值为null和重复数据后的结果 ----------------------------------------------------------------------------------------------------------------
举例演示如下: SQL> create table test
(
ename varchar2(),
sal number()
); 表已创建。 SQL> insert into test values('fxe1',); 已创建 行。 SQL> insert into test(ename) values('fxe2'); 已创建 行。 SQL> insert into test(ename) values('fxe3'); 已创建 行。 SQL> insert into test(ename) values('fxe4'); 已创建 行。 SQL> insert into test values('fxe5',); 已创建 行。 SQL> insert into test values('fxe6',); 已创建 行。 SQL> select * from test; ENAME SAL
---------- ----------
fxe1
fxe2
fxe3
fxe4
fxe5 fxe6 SQL> select count(*) from test; COUNT(*)
---------- SQL> select count(sal) from test; COUNT(SAL)
---------- SQL> select count(distinct sal) from test; COUNT(DISTINCTSAL)
------------------ SQL> select distinct sal from test; SAL
----------
  1. count(1)与count(*)比较:
  2. 如果你的数据表没有主键,那么count(1)比count(*)快
  3. 如果有主键的话,那主键(联合主键)作为count的条件也比count(*)要快
  4. 如果你的表只有一个字段的话那count(*)就是最快的啦
  5. count(*) count(1) 两者比较。主要还是要count(1)所相对应的数据字段。
  6. 如果count(1)是聚索引,id,那肯定是count(1)快。但是差的很小的。
  7. 因为count(*),自动会优化指定到那一个字段。所以没必要去count(?),用count(*),sql会帮你完成优化的
  8. count详解:
  9. count(*)将返回表格中所有存在的行的总数包括值为null的行,然而count(列名)将返回表格中除去null以外的所有行的总数(有默认值的列也会被计入).
  10. distinct 列名,得到的结果将是除去值为null和重复数据后的结果
  11. ----------------------------------------------------------------------------------------------------------------
  12. 举例演示如下:
  13. SQL> create table test
  14. 2 (
  15. 3 ename varchar2(10),
  16. 4 sal number(4)
  17. 5 );
  18. 表已创建。
  19. SQL> insert into test values('fxe1',90);
  20. 已创建 1 行。
  21. SQL> insert into test(ename) values('fxe2');
  22. 已创建 1 行。
  23. SQL> insert into test(ename) values('fxe3');
  24. 已创建 1 行。
  25. SQL> insert into test(ename) values('fxe4');
  26. 已创建 1 行。
  27. SQL> insert into test values('fxe5',80);
  28. 已创建 1 行。
  29. SQL> insert into test values('fxe6',80);
  30. 已创建 1 行。
  31. SQL> select * from test;
  32. ENAME SAL
  33. ---------- ----------
  34. fxe1 90
  35. fxe2
  36. fxe3
  37. fxe4
  38. fxe5 80
  39. fxe6 80
  40. SQL> select count(*) from test;
  41. COUNT(*)
  42. ----------
  43. 6
  44. SQL> select count(sal) from test;
  45. COUNT(SAL)
  46. ----------
  47. 3
  48. SQL> select count(distinct sal) from test;
  49. COUNT(DISTINCTSAL)
  50. ------------------
  51. 2
  52. SQL> select distinct sal from test;
  53. SAL
  54. ----------
  55. 80
  56. 90

Oracle 中count(1) 和count(*) 的区别的更多相关文章

  1. Oracle中执行存储过程call和exec区别

    Oracle中执行存储过程call和exec区别 在sqlplus中这两种方法都可以使用: exec pro_name(参数1..); call pro_name(参数1..); 区别: 1. 但是e ...

  2. Oracle中Blob和Clob类型的区别与操作

    Oracle中Blob和Clob类型 1.Oracle中Blob和Clob类型的区别 BLOB和CLOB都是大字段类型,BLOB是按二进制来存储的,而CLOB是可以直接存储文字的.其实两个是可以互换的 ...

  3. Oracle中Union与Union All的区别(适用多个数据库)

    Oracle中Union与Union All的区别(适用多个数据库) 如果我们需要将两个select语句的结果作为一个整体显示出来,我们就需要用到union或者union all关键字.union(或 ...

  4. Oracle中 (+)与left join 的用法区别

    Oracle中 (+)与left join 的用法区别 原创 2017年01月11日 13:33:42 6648 select * from a,b where a.id=b.id(+); (+)写在 ...

  5. Oracle中rank() over, dense_rank(), row_number() 的区别

    摘自:http://www.linuxidc.com/Linux/2015-04/116349.htm Oracle 中 rank() over, dense_rank(), row_number() ...

  6. Oracle中Null与空字符串' '的区别

    含义解释: 问:什么是NULL? 答:在我们不知道具体有什么数据的时候,也即未知,可以用NULL,我们称它为空,ORACLE中,含有空值的表列长度为零. ORACLE允许任何一种数据类型的字段为空,除 ...

  7. Oracle中varchar,varchar2,nvarchar,nvarchar2的区别及其它数据类型描述

    --varchar,varchar2 联系: 1.varchar/varchar2用于存储可变长度的字符串 比如varchar(20),存入字符串'abc',则数据库中该字段只占3个字节,而不是20个 ...

  8. oracle中int类型和number类型区别

    INT类型是NUMBER类型的子类型.下面简要说明:(1)NUMBER(P,S)该数据类型用于定义数字类型的数据,其中P表示数字的总位数(最大字节个数),而S则表示小数点后面的位数.假设定义SAL列为 ...

  9. ORACLE 中rownum和row_number()的使用区别(可指定取sql结果集的第几个数据)

    这篇文章主要介绍了oracle中rownum和row_number()的使用方法以及区别和联系,十分的详细,有需要的小伙伴可以参考下.   row_number()over(partition by ...

  10. (转)在oracle中varchar和varchar2有什么区别?

    1.varchar2把所有字符都占两字节处理(一般情况下),varchar只对汉字和全角等字符占两字节,数字,英文字符等都是一个字节: 2.VARCHAR2把空串等同于null处理,而varchar仍 ...

随机推荐

  1. Firefox上运行自动化测试脚本提示元素无法点击“WebDriverException: Message: Element is not clickable at point“解决方法

    1. Firefox上运行脚本时提示“WebDriverException: Message: Element is not clickable at point (934.316650390625, ...

  2. [日常训练]training

    Description 一条线上有栋楼,第栋楼有层,每层有1个价值为的物品. 可以花费1个单位时间完成以下3种移动: 1.在同一栋楼中向上或者向下走一层; 2.如果此刻在顶楼,可以通往1楼; 3.从当 ...

  3. [日常训练]最大M子段和

    Description 在长度为的序列中选出段互不相交的子段,求最大字段和. Input 第一行两个整数. 第二行个整数. Output 一行一个整数表示最大值. Sample Input 5 2 1 ...

  4. [NOIP2015] 提高组 洛谷P2661 信息传递

    题目描述 有n个同学(编号为1到n)正在玩一个信息传递的游戏.在游戏里每人都有一个固定的信息传递对象,其中,编号为i的同学的信息传递对象是编号为Ti同学. 游戏开始时,每人都只知道自己的生日.之后每一 ...

  5. Scala: 包对象

    包对象最重要的用途是兼容旧的类库,或者为某些数据类型提供增强版本:一般我们可以将其作为扩展工具方法或数据来使用

  6. Objective-C 利用OC的消息机制,使用Method Swizzling进行方法修改

    功能:修改父类不可修改函数方法,函数方法交换 应用场景:假如我们使用的他人提供一个的framework,.m已被打包成二进制.a无法修改源码,只留下.h头文件,那假如代码中某个函数出现了问题可以通过这 ...

  7. 解决“HTTP/1.1 405 Method not allowed”问题

    Apache.IIS.Nginx等绝大多数web服务器,都不允许静态文件响应POST请求,否则会返回"HTTP/1.1 405 Method not allowed"错误. 即,将 ...

  8. 系统安装之:虚拟机VMware V12.0.1 专业版 + 永久密钥

    撰写日期:2016-6-30 10:30:26 转自:http://blog.sina.com.cn/s/blog_4549d6770102vxue.html    VMware V12.0.1 专业 ...

  9. 【Beta版本】冲刺计划及安排

    目录 一.Beta的初步完善 二.团队分工的改进 三.工具流程的改进 四.冲刺阶段的计划与安排 五.关于组长是否重选 六.附录 队伍:606notconnected 成员:031401433 张斯巍  ...

  10. JavaScript 的错误(Error)与异常(Exception)处理

    PHP很少用到错误处理,因为框架帮了大忙,所以基本上没有主动接手过PHP的错误.PHP是偏后端的动态处理语言,和用户的关系不大,所以用户不会关心是否出现了报错.但是JavaScript就非常不同了,j ...