判断“存在“你还在用count吗,细节决定成败-阿里云开发者社区

开发者社区> 数据库> 正文

判断“存在“你还在用count吗,细节决定成败

简介: 为什么要用count(*) 在我们实际开发中,业务 往往是 如:(判断该手机是否已经存在),我们为了提高程序的运行效率,这个时候都会使用

@[toc]
在这里插入图片描述

1. 为什么要用count(*)

在我们实际开发中,业务 往往是 如:(判断该手机是否已经存在),我们为了提高程序的运行效率,这个时候都会使用

select count(*) from sys_user where phone = '18217692100'

在这里插入图片描述

//而我们Java代码
Integer count = mapper.selectCount(phone);
//写业务代码
if(count != 0){
  ……
else{
  ……
}

2. 优化方案

select 1 from sys_user where phone = '1821762100' LIMIT 1

在这里插入图片描述

//而我们Java代码
Integer count = mapper.selectCount(phone);
//写业务代码
if(count != null){
  ……
else{
  ……
}
  • SQL不再使用count,而是改用LIMIT 1,让数据库查询时遇到一条就返回,不要再继续查找还有多少条了
    业务代码中直接判断是否非空即可
  • 正所谓 ,细节决定成败 ,从速度上可以看出我们的优化方案快了好多

个人博客地址:http://blog.yanxiaolong.cn/

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享:
数据库
使用钉钉扫一扫加入圈子
+ 订阅

分享数据库前沿,解构实战干货,推动数据库技术变革

其他文章