MySQL利用help_topic表把以特殊字符分隔的字符串轉(zhuǎn)換成行

最近發(fā)現(xiàn)項(xiàng)目中首頁(yè)某個(gè)查詢(xún)很慢,點(diǎn)進(jìn)代碼一看原來(lái)是當(dāng)時(shí)用到了很多FIND_IN_SET函數(shù)查詢(xún)(因?yàn)楸碇凶侄问鞘褂枚禾?hào)分隔的字符串),F(xiàn)IND_IN_SET函數(shù)是不走索引的,那么對(duì)于FIND_IN_SET函數(shù)我們?cè)撊绾蝺?yōu)化呢?查閱了很多博客發(fā)現(xiàn)下面這種方法:MySQL為我們提供了一個(gè)help_topic表,該表中索引是從0自增的一共600多行,可使用該表把使用特定字符分隔的字符串替換成一列一列的數(shù)據(jù),可將FIND_IN_SET函數(shù)替換成IN查詢(xún)

SELECT
    #截取字符串 比如當(dāng)前字符串為 '1,2,3,4' 會(huì)將字符串截取為 
    #0 1
    #1 2
    #2 3
    #3 4
    #help_topic表中剩余的列全將為字符串最后一位
        help_topic_id,
    substring_index( substring_index( '1,2,3,4', ',', help_topic_id + 1 ), ',',- 1 ) 
FROM
    mysql.help_topic 
WHERE
    #控制行數(shù) (字符串整個(gè)長(zhǎng)度 - 去掉分隔符的長(zhǎng)度)+ 1 = 當(dāng)前字符串中所有被截取有效數(shù)據(jù)
    help_topic_id < ( length( '1,2,3,4' ) - length( REPLACE ( '1,2,3,4', ',', '' ))+ 1 );
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容