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 17:31
1 回复 分享
发布于 2022-05-30 11:43
1 回复 分享
发布于 2022-05-30 11:37
跟着大佬,每天学习一个小技巧😎
点赞 回复 分享
发布于 2022-07-19 11:58
点赞 回复 分享
发布于 2022-05-29 01:53

相关推荐

小浪_Coding:找硬件测试,也可兼顾软测欧, 简历还可以的 ,注意排版,项目写的有条理一点, 然后个人技能多加点, 润色好简历之后就开始沟通海投了,深圳,东莞这边做硬件相关的公司还不少, 医疗类,仪器类的都可以尝试
点赞 评论 收藏
分享
Lorn的意义:你这种岗位在中国现在要么牛马天天加班,要么关系户进去好吃好喝,8年时间,真的天翻地覆了,对于资本来说你就说一头体力更好的牛马,哎,退伍没有包分配你真的亏了。
点赞 评论 收藏
分享
评论
13
9
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务