@[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/