文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2024-11-30 00:28

关注

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');

执行结果:

图片

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;

图片

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

适用场景

总结

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

来源:码农Academy内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯