在mysql中提供了一些字符串操做的函数,其中SUBSTRING_INDEX(str, delim, count)mysql
str: 要处理的字符串sql
delim: 分割符函数
count: 计数 若是为正数,则从左开始数,若是为负数,则从右开始数设计
例:字符串
str = 'www.baidu.com';string
SELECT substring_index('www.baidu.com','.', 1); #www
SELECT substring_index('www.baidu.com','.', 2); #www.baidu
SELECT substring_index('www.baidu.com','.', -1); #com
SELECT substring_index('www.baidu.com','.', -2); #baidu.com
SELECT substring_index(substring_index('www.baidu.com','.', -2), '.', 1); #baidu
有了这个函数的帮助,咱们还须要肯定什么呢?须要知道 当前要分割的位置
如何来获取当前要分割的位置呢?咱们能够先获取总共能拆分红多少个字符串
SELECT LENGTH('1,2,3,4,5,6,7') - LENGTH(REPLACE('1,2,3,4,5,6,7', ',', '')) + 1;
结果为7,那么其实咱们想要的就是遍历1到6,分别获取当前位置的字符串:SELECT substring_index(substring_index('1,2,3,4,5,6,7',',', index), ',', -1)
其中index就是咱们要遍历的位置,因此为了遍历,咱们须要一个关联一个辅助表来获得当前位置,最后的设计以下:
SELECT substring_index(substring_index(t.context,',', b.help_topic_id + 1), ',', -1) FROM test.test t join mysql.help_topic b ON b.help_topic_id < (LENGTH(t.context) - LENGTH(REPLACE(t.context, ',', '')) + 1);test