mysql拆分字符串作為查詢條件的示例代碼
有個(gè)群友問一個(gè)問題
這表的ancestors列存放的是所有的祖先節(jié)點(diǎn),以,
分隔
例如我查詢dept_id為103的所有祖先節(jié)點(diǎn),現(xiàn)在我只有一個(gè)dept_id該怎么查
然后我去網(wǎng)上找到這樣一個(gè)神奇的sql,改改表名就成了下面的這樣
SELECT substring_index( substring_index( a.ancestors, ',', b.help_topic_id + 1 ), ',',- 1 ) AS shareholder FROM sys_dept a JOIN mysql.help_topic b ON b.help_topic_id < ( length( a.ancestors ) - length( REPLACE ( a.ancestors, ',', '' ) ) + 1 ) WHERE dept_id = 103
嗯,沒錯(cuò)結(jié)果出來了,然后我就很好奇,什么原理,一個(gè)個(gè)來看
mysql.help_topic
這個(gè)是一個(gè)mysql自帶的幫助解釋注釋表,查詢結(jié)果如下
id從0開始,我這個(gè)版本最大id到584,版本不同應(yīng)該id最大值也不一樣,這個(gè)表的作用一會說
REPLACE
這個(gè)函數(shù)應(yīng)該都知道吧,替換字符用的
LENGHT
獲取字符串的長度
substring_index
查分字符串,三個(gè)參數(shù),要拆分的字符串,根據(jù)拆分的字符,從第幾個(gè)開始
如果最后的那個(gè)參數(shù)為正數(shù)則從左開始數(shù),然后獲取對應(yīng)下標(biāo)左邊的所有字符
如果為負(fù)數(shù),則從右邊開始數(shù),獲取對應(yīng)下標(biāo)右邊的所有字符串,這個(gè)就不演示了
分析
先來看第一段
( length( a.ancestors ) - length( REPLACE ( a.ancestors, ',', '' ) ) + 1 )
我們假設(shè)當(dāng)前數(shù)據(jù)的ancestors值為 0,100,101
那么第一個(gè)length(a.ancestors)
的值就是9 減去后面的一段
length( REPLACE ( a.ancestors, ',', '' ) )
因?yàn)槲覀兗僭O(shè)的值里面有兩個(gè) ,
所以length為7 最后在加1 那么這段值為 3
和前面的 join on條件能查出的數(shù)據(jù)也就是mysql.help_topic
這個(gè)表中所有id小于3的數(shù)據(jù),也就是id為0,1,2的三條數(shù)據(jù)
那么現(xiàn)在先來看看這樣查詢的結(jié)果是啥
那么我們假設(shè)現(xiàn)在是第一行,mysql.help_topic
表中的help_topic_id
為0
substring_index( substring_index( a.ancestors, ',', b.help_topic_id + 1 ), ',',- 1 )
最里面的substring_index 拆分后為0,因?yàn)闆]有能在拆分的了所以外面的substring_index返回的也是0
第二行help_topic_id
為1的時(shí)候獲取結(jié)果為0,100
然后執(zhí)行外層的substring_index 根據(jù),
拆分,值為-1 所以從右邊找一位,獲取的值就是100
第三行結(jié)果為0,100,101
,外層substring_index 執(zhí)行后結(jié)果為101
....只能心中大喊牛逼
那么現(xiàn)在知道mysql.help_topic
這個(gè)表的作用了嗎?就是用來對拆分出的數(shù)據(jù)分行,專業(yè)點(diǎn)叫笛卡爾積
(真的不懂..)
這種方法也有缺點(diǎn):就是拆出的行數(shù)不能大于mysql.help_topic
這個(gè)表的數(shù)據(jù)條數(shù)
到此這篇關(guān)于mysql拆分字符串作為查詢條件的示例代碼的文章就介紹到這了,更多相關(guān)mysql拆分字符串查詢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySQL中的常用樹形結(jié)構(gòu)設(shè)計(jì)總結(jié)
這篇文章主要介紹了MySQL中的常用樹形結(jié)構(gòu)設(shè)計(jì)總結(jié),具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03mysql 一個(gè)較特殊的問題:You can''t specify target table ''wms_cabinet
mysql 一個(gè)較特殊的問題:You can't specify target table 'wms_cabinet_form' for update in F2010-11-11mysql正確刪除數(shù)據(jù)的方法(drop,delete,truncate)
這篇文章主要給大家介紹了關(guān)于mysql正確刪除數(shù)據(jù)的相關(guān)資料,DELETE語句是MySQL中最常用的刪除數(shù)據(jù)的方式之一,但也有幾種其他方法來實(shí)現(xiàn),需要的朋友可以參考下2023-10-10MYSQL的REPLACE和ON DUPLICATE KEY UPDATE語句介紹解決問題實(shí)例
這篇文章主要介紹了MYSQL的REPLACE和ON DUPLICATE KEY UPDATE語句介紹解決問題實(shí)例,需要的朋友可以參考下2014-04-04詳解mysql集群:一主多從架構(gòu)實(shí)現(xiàn)
這篇文章主要介紹了mysql集群一主多從架構(gòu)實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05