欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql拆分字符串作為查詢條件的示例代碼

 更新時(shí)間:2022年07月06日 08:25:01   作者:Jame!  
本文主要介紹了mysql拆分字符串作為查詢條件的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

有個(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)文章

最新評論