服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Mysql - 求求你别再用COUNT(*)判断数据存不存在了,很浪费资源的

求求你别再用COUNT(*)判断数据存不存在了,很浪费资源的

2024-03-14 15:14码农Academy Mysql

在日常业务系统开发中,我们尝尝有这样的一个需求:判断某个值在数据库中是否存在。常见的做法之一是使用COUNT(*)或者COUNT(1)函数,但是,在仅需判断记录是否存在而不关注具体数量的情况下,采用EXISTS子句或LIMIT 1查询往往能提

引言

在日常业务系统开发中,我们尝尝有这样的一个需求:判断某个值在数据库中是否存在。常见的做法之一是使用COUNT(*)或者COUNT(1)函数,但是,在仅需判断记录是否存在而不关注具体数量的情况下,采用EXISTS子句或LIMIT 1查询往往能提供更高的查询性能和更低的系统资源消耗。

COUNT()函数的局限性

使用COUNT(*)或者COUNT(1)先查询出来这个值在数据库中对应的记录的行数,然后在代码中判断sql返回的数据条数是否大于0,即可确认是否存在。

SELECT COUNT(*) FROM t_order WHERE order_no = 'c535cd19-9d1d-46';

然后代码中判断:

int count = orderMapper.countOrder(orderNo);
if (count > 0){
    System.out.println("单号已存在");
}else{
    System.out.println("单号不存在");
}

虽然这种写法没有问题,能得到是否大于0的结论,可以实现业务需求,但是呢,COUNT(*)会遍历所有满足条件的行,即便你并不关心具体的行数,也会消耗较大的系统资源。特别是当表的数据量非常大时,这种查询可能导致性能瓶颈。尽管在有适当索引的情况下,MySQL可以有效地处理COUNT(*)查询,但在仅需判断是否存在的情况下,利用索引的优势不如EXISTS和LIMIT 1明显。并且EXISTS和LIMIT 1也可以利用索引。

关于COUNT()函数更多的介绍,请移步:面试官:请说一下Mysql中count(1)、count(*)以及count(列)的区别?

EXISTS子句的优势

EXISTS子句是用来检查是否存在满足条件的行。例如上述示例修改为:

SELECT EXISTS(SELECT id FROM t_order WHERE order_no = 'c535cd19-9d1d-46');

执行结果:

求求你别再用COUNT(*)判断数据存不存在了,很浪费资源的图片

EXISTS子句内的查询返回至少一行数据时,它将立刻返回TRUE(即1)。这意味着一旦找到匹配项,MySQL就可以停止进一步的扫描,因此在只需判断记录是否存在时,其性能表现优于COUNT(*)。EXISTS子句更适合于复杂的嵌套查询中,作为逻辑判断条件。

关于EXISTS子句更多的介绍,请移步:面试官:Mysql中EXISTS与IN有哪些使用差异?

LIMIT 1 优势

LIMIT的用法就不多介绍了。而LIMIT 1查询在找到第一条满足条件的记录时就结束搜索。

SELECT id FROM t_order WHERE order_no = 'c535cd19-9d1d-46' LIMIT 1;

求求你别再用COUNT(*)判断数据存不存在了,很浪费资源的图片

LIMIT 1查询同样会在找到第一条满足条件的记录时就结束搜索,因此在判断是否存在记录时具备很高的效率。并且,与EXISTS相比,LIMIT 1还额外提供了匹配记录的具体信息。这对于那些在判断存在性的同时还需要获取记录部分内容或全部内容的场景来说,是一个理想的解决方案。

适用场景

  • EXISTS适用于只需要知道记录是否存在的情况,尤其适合在复杂查询的子查询中作为条件判断。
  • LIMIT 1适用于在确定记录存在时同时需要获取该记录部分或全部数据的场合。
  • COUNT(*)在需要统计满足特定条件的记录总数时更为适用。

总结

在仅仅需要判断数据库中是否存在满足特定条件的记录时,使用EXISTS子句或带有LIMIT 1的查询不仅能够提高查询效率,减少资源消耗,还能根据需求灵活地获取相关数据。尽管COUNT(*)在统计记录数量上有其不可替代的价值,但在判断记录是否存在这一特定任务上,我们应该优先考虑更加高效且针对性强的EXISTS和LIMIT 1查询策略。这样才能更好地优化数据库性能,提升应用响应速度。

原文地址:https://mp.weixin.qq.com/s/9-Mgw_KUZD5R1TPOpdwbAg

延伸 · 阅读

精彩推荐
  • Mysql全面解析MySQL中的隔离级别

    全面解析MySQL中的隔离级别

    这篇文章主要介绍了MySQL中的隔离级别的相关资料,帮助大家更好的理解和使用MySQL,感兴趣的朋友可以了解下。...

    以战止殇7602021-04-04
  • MysqlLInux下安装MySQL5.6 X64版本步骤详解

    LInux下安装MySQL5.6 X64版本步骤详解

    这篇文章主要介绍了LInux下安装MySQL5.6 X64版本步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下...

    srx93112911152020-09-20
  • Mysql一文搞懂MySQL脏读,幻读和不可重复读

    一文搞懂MySQL脏读,幻读和不可重复读

    这篇文章主要介绍了一文搞懂MySQL脏读,幻读和不可重复读,MySQL 默认的事务隔离级别是可重复读,文章通过MySQL 中事务的隔离级别展开全文详细内容,需要...

    Java中文社群11612022-09-16
  • Mysqlmysql 5.6.13 免安装版配置方法详解

    mysql 5.6.13 免安装版配置方法详解

    这篇文章主要介绍了mysql 5.6.13 免安装版配置的方法,今天小编把配置方法分享到服务器之家平台供大家参考下 ...

    MYSQL教程网5262020-06-28
  • MysqlMySQL如何确定VARCHAR大小问题

    MySQL如何确定VARCHAR大小问题

    本文主要介绍了MySQL如何确定VARCHAR大小问题,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    杨林伟11662022-09-22
  • MysqlMySQL中UNION与UNION ALL的基本使用方法

    MySQL中UNION与UNION ALL的基本使用方法

    这篇文章主要给大家介绍了关于MySQL中UNION与UNION ALL的基本使用方法,文中通过示例代码介绍的非常详细,对大家学习或者使用MySQL具有一定的参考学习价值...

    a7579561322812020-12-21
  • MysqlCentOS7使用rpm包安装mysql 5.7.18

    CentOS7使用rpm包安装mysql 5.7.18

    这篇文章主要为大家详细介绍了CentOS7使用rpm包安装mysql 5.7.18的相关步骤,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 ...

    garvenc3552020-07-30
  • MysqlWindows安装MySQL 5.7.18 解压版的教程

    Windows安装MySQL 5.7.18 解压版的教程

    这篇文章主要为大家详细介绍了Windows安装MySQL 5.7.18 解压版的详细教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 ...

    Spade-A3782020-08-04