溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

sql?in查詢(xún)?cè)爻^(guò)1000條如何解決

發(fā)布時(shí)間:2023-03-07 16:13:26 來(lái)源:億速云 閱讀:184 作者:iii 欄目:MySQL數(shù)據(jù)庫(kù)

這篇文章主要介紹“sql in查詢(xún)?cè)爻^(guò)1000條如何解決”,在日常操作中,相信很多人在sql in查詢(xún)?cè)爻^(guò)1000條如何解決問(wèn)題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”sql in查詢(xún)?cè)爻^(guò)1000條如何解決”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!

    一、場(chǎng)景描述

    查詢(xún)機(jī)構(gòu)下的人員,要同時(shí)查詢(xún)出該機(jī)構(gòu)及其所有下級(jí)機(jī)構(gòu)的人員;比如查詢(xún)北京市,不僅要查詢(xún)出歸屬于北京市的人員,還要查詢(xún)歸屬于出朝陽(yáng)區(qū)、西城區(qū)、海淀區(qū)等等的人員。

    對(duì)于這個(gè)需求,有以下幾種解決思路:

    1、之前的系統(tǒng),他們的機(jī)構(gòu)編碼本身有關(guān)聯(lián),比如北京編碼是001的話,昌平區(qū)的編碼就是0012;這樣的話,他們查詢(xún)可以用like。這種方法的問(wèn)題是like查詢(xún)太慢,尤其在數(shù)據(jù)量大的時(shí)候,即使對(duì)編碼加唯一索引,也只有查最根部機(jī)構(gòu)時(shí)可以走索引(因?yàn)橹挥写藭r(shí)才符合最左前綴)。

    2、我們的系統(tǒng)沒(méi)有機(jī)構(gòu)編碼,唯一標(biāo)識(shí)是雪花算法生成的19位id,沒(méi)有關(guān)聯(lián);機(jī)構(gòu)關(guān)系是通過(guò)一張關(guān)聯(lián)表組合的起來(lái)的(適用于多業(yè)務(wù)系統(tǒng),多機(jī)構(gòu)樹(shù)的情況)。這種情況,可以通過(guò)條件從關(guān)系表中查出所有下級(jí)機(jī)構(gòu)id,然后查詢(xún)時(shí)用in查詢(xún);為了方便查詢(xún),我們還建了一張機(jī)構(gòu)關(guān)系冗余表。
    但是這種方法也有一個(gè)問(wèn)題,就是Oracle數(shù)據(jù)庫(kù)in查詢(xún)中元素,必須在1000以?xún)?nèi)。

    二、解決方案

    1、方案一:核心思路是,將集合拆分,使用or 連接。

    select * from A where id in (1, 2, …, 1000) or id in (1001, …, 1999)

    用mybatis的話就是這樣

    select * from test_1
    <where>
     <if test="list != null and list.size > 0">
        (id IN
        <!-- 處理in的集合超過(guò)1000條時(shí)Oracle不支持的情況 -->
        <trim suffixOverrides=" OR id IN()">
            <foreach collection="list " item="Id" index="index" open="(" close=")">
                <if test="index != 0">
                    <choose>
                        <when test="index % 1000 == 999">) OR id IN (</when>
                        <otherwise>,</otherwise>
                    </choose>
                </if>
                #{Id}
            </foreach>
        </trim>
        )
     </if>

    但是這種方法不好用,實(shí)測(cè)中3萬(wàn)條左右的機(jī)構(gòu),用這種查詢(xún)查了好久都沒(méi)出來(lái),感覺(jué)數(shù)據(jù)庫(kù)都要奔潰了。

    2、方案二:用子查詢(xún)(臨時(shí)表)+關(guān)聯(lián)查詢(xún)

    一般來(lái)說(shuō),超過(guò)1000多條的數(shù)據(jù),肯定不是用戶(hù)填寫(xiě)的,而是從其他地方查詢(xún)出來(lái)的;我們可以將這些數(shù)據(jù)放到一個(gè)臨時(shí)表中(用子查詢(xún)實(shí)現(xiàn)),然后用內(nèi)連接關(guān)聯(lián)查詢(xún)。

    sql?in查詢(xún)?cè)爻^(guò)1000條如何解決

    該查詢(xún)中,機(jī)構(gòu)關(guān)系冗余表SEP_SYSTEM_ORG_RELATION中有20多萬(wàn)條數(shù)據(jù),但子查詢(xún)走了我們創(chuàng)建的組合索引;整個(gè)查詢(xún)只用了0.367秒

    sql?in查詢(xún)?cè)爻^(guò)1000條如何解決

    到此,關(guān)于“sql in查詢(xún)?cè)爻^(guò)1000條如何解決”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注億速云網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!

    向AI問(wèn)一下細(xì)節(jié)

    免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

    AI