SQL查找是否"存在",别再count了!

根据某一条件从数据库表中查询 『有』与『没有』,只有两种状态,那为什么在写SQL的时候,还要SELECT count(*)呢?

无论是刚入道的程序员新星,还是精湛沙场多年的程序员老白,都是一如既往的count

目前多数人的写法

多次REVIEW代码时,发现如现现象:

业务代码中,需要根据一个或多个条件,查询是否存在记录,不关心有多少条记录。普遍的SQL及代码写法如下

SQL写

SELECT count(*) FROM table WHERE a = 1 AND b = 2

Java写法

int nums = xxDao.countXxxxByXxx(params); if ( nums > 0 ) {  //当存在时,执行这里的代码 } else {  //当不存在时,执行这里的代码 }


是不是感觉很OK,没有什么问题

优化方案

推荐写法如下:

SQL写法

SELECT 1 FROM table WHERE a = 1 AND b = 2 LIMIT 1

Java写法

Integer exist = xxDao.existXxxxByXxx(params); if ( exist != NULL ) {  //当存在时,执行这里的代码 } else {  //当不存在时,执行这里的代码 }

SQL不再使用count,而是改用LIMIT 1,让数据库查询时遇到一条就返回,不要再继续查找还有多少条了

业务代码中直接判断是否非空即可

总结

根据查询条件查出来的条数越多,性能提升的越明显,在某些情况下,还可以减少联合索引的创建。

本文正在参与【内行知多少】 征文活动,一起来聊聊内行人才懂的那些事吧,高额牛币和百元京东卡等你来领~


#搞技术你要知道##春招##笔试题目##面经##笔经##Java##MySQL##技术栈#
全部评论
{"pureText":"","imgs":[{"alt":"discuss_165****659429.jpeg","height":538,"localSrc":"content://com.miui.gallery.open/raw/%2Fstorage%2Femulated%2F0%2FPictures%2FWeiXin%2Fmmexport165****079488.jpg","src":"https://uploadfiles.nowcoder.com/message_images/20220529/365621276_1653760661674/discuss_1653760659429.jpeg","width":600}]}
4 回复
分享
发布于 2022-05-29 01:57
1 回复
分享
发布于 2022-05-30 11:37
小红书
校招火热招聘中
官网直投
1 回复
分享
发布于 2022-05-30 11:43
点赞 回复
分享
发布于 2022-05-29 01:53
跟着大佬,每天学习一个小技巧😎
点赞 回复
分享
发布于 2022-07-19 11:58

相关推荐

13 9 评论
分享
牛客网
牛客企业服务