二維碼
        企資網(wǎng)

        掃一掃關(guān)注

        當(dāng)前位置: 首頁 » 企資快訊 » 匯總 » 正文

        SQL判斷是否"存在",還在用_count_操

        放大字體  縮小字體 發(fā)布日期:2022-12-10 07:33:28    作者:葉譯峰    瀏覽次數(shù):45
        導(dǎo)讀

        按照某那條件從數(shù)據(jù)庫附注查看 『有』與『不會』,僅剩幾種狀態(tài),那難道在寫SQL得時候,就要select count(*) 呢?不管剛?cè)氲赖贸绦騿T新星,畢竟精良沙場三十多年得程序員老白,都是一如既往得count.目前少數(shù)人

        按照某那條件從數(shù)據(jù)庫附注查看 『有』與『不會』,僅剩幾種狀態(tài),那難道在寫SQL得時候,就要select count(*) 呢?

        不管剛?cè)氲赖贸绦騿T新星,畢竟精良沙場三十多年得程序員老白,都是一如既往得count.

        目前少數(shù)人得讀音

        曾多次 review 代碼時,發(fā)覺常房現(xiàn)象:

        業(yè)務(wù)代碼中,必須按照這個或十多個條件,查看除非隱含記錄,不關(guān)心有甚么條記錄。普遍得SQL及代碼讀音如下

        SQL讀音:

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

        Java讀音:

        int nums = xxDao.countXxxxByXxx(params);
        if ( nums > 0 ) {
        //當(dāng)隱含時,執(zhí)行者那兒得代碼
        } else {
        //利穆縣隱含時,執(zhí)行者那兒得代碼
        }

        是不是感覺很OK,不會什么樣問題

        優(yōu)化方案

        極力推薦讀音如下:

        SQL讀音:

        SELECt 1 FROM table WHERe a = 1 AND b = 2 LIMIT 1

        Java讀音:

        Integer exist = xxDao.existXxxxByXxx(params);
        if ( exist != NULL ) {
        //當(dāng)隱含時,執(zhí)行者那兒得代碼
        } else {
        //利穆縣隱含時,執(zhí)行者那兒得代碼
        }

        SQL無須選用count,所以換用LIMIT 1,讓數(shù)據(jù)庫查看時碰上那條就抵達,不要再繼續(xù)檢索有甚么條了

        業(yè)務(wù)代碼中直接判斷除非非空亦可

        總結(jié)

        按照查看條件確知得條數(shù)越多,性能大幅提升拜翁縣大幅度,在這類情況下,還可減低聯(lián)合體索引得創(chuàng)辦。

        更多文章資訊:特別999la/article/

        感謝:特別999la/shujukuwz/884764ab9cb1868e4582.html

         
        (文/葉譯峰)
        免責(zé)聲明
        本文僅代表作發(fā)布者:葉譯峰個人觀點,本站未對其內(nèi)容進行核實,請讀者僅做參考,如若文中涉及有違公德、觸犯法律的內(nèi)容,一經(jīng)發(fā)現(xiàn),立即刪除,需自行承擔(dān)相應(yīng)責(zé)任。涉及到版權(quán)或其他問題,請及時聯(lián)系我們刪除處理郵件:weilaitui@qq.com。
         

        Copyright ? 2016 - 2025 - 企資網(wǎng) 48903.COM All Rights Reserved 粵公網(wǎng)安備 44030702000589號

        粵ICP備16078936號

        微信

        關(guān)注
        微信

        微信二維碼

        WAP二維碼

        客服

        聯(lián)系
        客服

        聯(lián)系客服:

        在線QQ: 303377504

        客服電話: 020-82301567

        E_mail郵箱: weilaitui@qq.com

        微信公眾號: weishitui

        客服001 客服002 客服003

        工作時間:

        周一至周五: 09:00 - 18:00

        反饋

        用戶
        反饋

        主站蜘蛛池模板: 国产在线精品一区二区在线看| 91久久精一区二区三区大全| 高清国产精品人妻一区二区| 日韩免费一区二区三区在线播放 | 精品成人av一区二区三区| 无码精品久久一区二区三区 | 台湾无码AV一区二区三区| 欧美日本精品一区二区三区| 九九久久99综合一区二区| 影院无码人妻精品一区二区| 国产精品无码亚洲一区二区三区| 中文字幕一区二区三区精华液| 国产精品日韩一区二区三区| 亚洲高清一区二区三区电影 | 少妇精品久久久一区二区三区 | 国产主播一区二区| 色狠狠AV一区二区三区| 99久久精品午夜一区二区| 久久久久女教师免费一区| 曰韩人妻无码一区二区三区综合部| 人妻体体内射精一区二区| 内射一区二区精品视频在线观看| 无码国产精成人午夜视频一区二区 | 日本免费一区尤物| 亚洲一区二区观看播放| 91精品国产一区二区三区左线 | 亚洲日本久久一区二区va| 亚洲AV无一区二区三区久久 | 亚洲av成人一区二区三区在线观看 | 国产精品丝袜一区二区三区| 中文字幕VA一区二区三区| 国产精品一区二区av| 亚洲AV福利天堂一区二区三| 色久综合网精品一区二区| 在线观看免费视频一区| 亚洲国产日韩一区高清在线| 亚洲一区二区三区在线观看蜜桃| 亚洲国产高清在线精品一区| 另类ts人妖一区二区三区| 在线成人一区二区| 亚洲av无码天堂一区二区三区|