二維碼
        企資網(wǎng)

        掃一掃關(guān)注

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

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

        放大字體  縮小字體 發(fā)布日期:2022-12-10 07:33:28    作者:葉譯峰    瀏覽次數(shù):50
        導(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ù)庫查看時碰上那條就抵達(dá),不要再繼續(xù)檢索有甚么條了

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

        總結(jié)

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

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

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

         
        (文/葉譯峰)
        免責(zé)聲明
        本文僅代表作發(fā)布者:葉譯峰個人觀點,本站未對其內(nèi)容進(jìn)行核實,請讀者僅做參考,如若文中涉及有違公德、觸犯法律的內(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

        反饋

        用戶
        反饋

        主站蜘蛛池模板: 国产亚洲一区二区手机在线观看 | 亚洲一区二区影院| 亲子乱AV视频一区二区| 国产成人高清亚洲一区91| 国产精品一区二区久久精品| 国产人妖视频一区二区 | 亚洲电影国产一区| 精品无码综合一区| 亚洲片国产一区一级在线观看| 免费高清av一区二区三区| 精品成人乱色一区二区| 黑人大战亚洲人精品一区| 亚洲国产av一区二区三区| 视频一区视频二区日韩专区| 美女AV一区二区三区| 无码人妻一区二区三区免费视频 | 国精产品一区一区三区免费视频 | 一区二区三区免费精品视频| 精品国产天堂综合一区在线| 无码人妻精一区二区三区 | 麻豆天美国产一区在线播放| 无码视频一区二区三区在线观看| 波多野结衣免费一区视频| 国产一区二区视频在线播放| 99久久国产精品免费一区二区| 内射女校花一区二区三区| 国产成人精品一区二区三区免费| 久久国产高清一区二区三区| 另类免费视频一区二区在线观看| 日韩一区二区久久久久久| 精品深夜AV无码一区二区| 国产精品香蕉一区二区三区| 日韩精品国产一区| 国产激情一区二区三区 | 久久国产一区二区| 亚洲日韩AV无码一区二区三区人| 国产精品福利一区| 狠狠色成人一区二区三区| 精品欧洲AV无码一区二区男男| 精品日韩一区二区| 丰满少妇内射一区|