count(1)、count(*)和count(指定字段)之间的区别

这篇具有很好参考价值的文章主要介绍了count(1)、count(*)和count(指定字段)之间的区别。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、count(1)和count(*)
当表的数据量比较大,对表作分析之后,使用count(1)比使用count(*)用时多。
从执行计划看,count(1)和count(*)的效果是一样的。 但是在表做过分析之后,count(1)会比count()的用时少些。
如果count(1)是聚索引,id,那肯定是count(1)快。但是差的很小的。
因为count(*),自动会优化指定到那一个字段。所以没必要去count(1),用count(*),sql会帮你完成优化,所以count(1)和count()基本没有差别。

二、count(1)和count(指定字段)
两者的主要区别是
(1) count(1) 会统计表中的所有的记录数, 包含字段为null 的记录。
(2) count(字段) 会统计该字段在表中出现的次数,忽略字段为null 的情况。即 不统计字段为null 的记录。

三、count(*) 和 count(1)和count(指定字段)区别
执行效果上 :
count(*)包括了所有的列,相当于行数,在统计结果的时候, 不会忽略列值为NULL
count(1)包括了忽略所有列,用1代表代码行,在统计结果的时候, 不会忽略列值为NULL
count(字段)只包括列名那一列,在统计结果的时候,会忽略列值为空(这里的空不是只空字符串或者0,而是表示null)的计数, 即某个字段值为NULL时,不统计。

执行效率上:
列名为主键,count(指定字段)会比count(1)快
列名不为主键,count(1)会比count(指定字段)快
如果表多个列并且没有主键,则 count(1) 的执行效率优于 count(*)
如果有主键,则 select count(主键)的执行效率是最优的
如果表只有一个字段,则 select count(*)最优。文章来源地址https://www.toymoban.com/news/detail-426895.html

到了这里,关于count(1)、count(*)和count(指定字段)之间的区别的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • jsonpath提取字段某个字段为指定值的其他字段数据&提取某个字段的所有值

    1.jsonpath提取某个字段为指定值的其他字段数据 [ [ { “code”: “a255e81dc5a5442e”, “name”: “原始货号”, “values”: [ { “code”: “223e768a1b18b64c”, “attrCode”: “a255e81dc5a5442e”, “displayName”: “P11”, “frontName”: “P11”, “images”: [], “originCode”: “P11” } ], “originCode”: “

    2024年01月23日
    浏览(46)
  • Debezium系列之:多张表按照指定的字段分发数据到Kafka Topic,并保证多张表指定字段相同的值始终出现在相同分区

    根据productInfo和productorder两张表的productId分发数据,相同productId的数据始终出现在相同分区,并且希望两张表相同的订单数据也始终出现在相同分区。 例如关于productInfo表1206827245738502144这个订单的增删改数据始终出现在分区2,那productorder这个表1206827245738502144这个订单的增删

    2024年02月09日
    浏览(44)
  • C#获取DataTable的前N行数据然后按指定字段排序

    可以使用以下三种代码: 控制台应用程序FilterDataTableDemo  

    2024年02月11日
    浏览(42)
  • count(0)、count(1)和count(*)、count(列名) 的区别

    当我们对一张数据表中的记录进行统计的时候,习惯都会使用 count 函数来统计,但是 count 函数传入的参数有很多种,比如 count(1)、count( * )、count(字段) 等。 到底哪种效率是最好的呢?是不是 count( * ) 效率最差? 一. 哪种 count 性能最好? 哪种 count 性能最好? 我先直接说结论

    2024年02月08日
    浏览(34)
  • count(列名)、count(1)和 count(*)有什么区别?

    在MySQL中,这几个都是统计操作,很多人在使用的时候,都使用的是count(1),这有没有问题?使用正确?达到了统计效果? 我们从效果和效率两方面来分析下 count(*) 包括了所有的列,在统计时不会忽略列值为null的数据 count(1) 用1表示代码行,在统计时不会忽略列值为null的数据

    2024年02月02日
    浏览(31)
  • Java通过Lambda表达式根据指定字段去除重复数据(集合去重)

    这里博主给大家封装好了一个工具类,里面有两个方法。 方法一:可以根据指定字段去除重复数据。 方法二:可以获取到重复的数据。 大家在使用过程中直接拷贝下方代码在要去重的类中调用即可。 导入这个工具类后怎么使用呢?我们接着往下看。 List rstList = list.stream()

    2024年02月16日
    浏览(57)
  • SQL count(1)、count(*) 与 count(列名) 到底有什么区别?

    count(*) 和 count(1)和count(列名)区别 执行效果上: count(*)包括了所有的列,相当于行数,在统计结果的时候,不会忽略为NULL的值。 count(1)包括了忽略所有列,用1代表代码行,在统计结果的时候,不会忽略为NULL的值。 count(列名)只包括列名那一列,在统计结果的时候,会忽略列值

    2024年02月11日
    浏览(36)
  • mysql面试题38:count(1)、count(*) 与 count(列名) 的区别

    该文章专注于面试,面试只要回答关键点即可,不需要对框架有非常深入的回答,如果你想应付面试,是足够了,抓住关键点 当使用COUNT函数进行数据统计时,有三种常见的用法:COUNT(1)、COUNT(*)和COUNT(列名)。它们的区别如下: COUNT(1):在COUNT函数中使用1作为参数,表示统计

    2024年02月07日
    浏览(32)
  • 数据挖掘和数据仓库之间的区别

    数据仓库是一种用于收集和管理来自不同来源的数据以提供有意义的业务见解的技术。它是技术和组件的混合体,允许战略性地使用数据。 数据仓库是企业对大量信息的电子存储,旨在进行查询和分析,而不是事务处理。这是一个将数据转换为信息并将其提供给用户进行分析

    2024年02月04日
    浏览(46)
  • 面试官:请说一下Mysql中count(1)、count(*)以及count(列)的区别?

    近期在Review项目代码时,发现同事们在查询MySQL行数时存在多样的方式,有的使用 COUNT(1) , 有的用 COUNT(id) , 还有人选择了 COUNT(*) 。这混杂的选择引发了我的思考。当然这三种count的方式也是众说纷纭,其中最大的分歧点就是 COUNT(*) 和 COUNT(1) 查询性能上,有人觉得 COUNT(*) 需要

    2024年02月19日
    浏览(39)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包