我们可以看出,instr是找出 参数2=》也就是上图中的 ‘123’ 在参数1=》也就是上图中的 ‘321,123,555,12345’ 中最开始出现的位置;
所以我们也只需要 where find_in_set(ids,id)>0 ,就可以判断出 id 在 ids中出现过;
但这有一个问题,如果逗号分隔开的字符串,包含我们查找的字符串,也会显示出来,这就不符合我们 根据分隔符 , 判断 查找字符串id 是否出现在 ids 中;
我们本来想查以逗号为分隔的完全匹配,但是12345包含了 123 所以查出来的结果也是>0的,这不对;
所以我们为了避免这种情况,可以加上分隔符;然后再用 字符串+分隔符作为 查找的字符串 来 匹配;
我们被查找的字符串 ids 中 再加上一个正常的 123, 再查看,如下图:确实是对的
一些特殊数据,可能字符串拆分出来后缀有的相同,就会造成结果错误,例如以下:
在字符串中搜索 ‘23’的位置,‘123’的后缀也是’23’,就会造成结果错误
可以在字符串两边都加上逗号,确保字符串能完全匹配
SELECT
substring_index( ids, ',', 1 ) id1,
SUBSTR( substring_index( ids, ',', 2 ), LOCATE( ',', substring_index( ids, ',', 2 ), 1 )+ 1 ) id2,
SUBSTR(
ids,
LENGTH(
CONCAT(
substring_index( ids, ',', 1 ),
SUBSTR( substring_index( ids, ',', 2 ), LOCATE( ',', substring_index( ids, ',', 2 ), 1 ) )))+ 2
) id3
( SELECT REPLACE ( REPLACE ( '[52,15,894]', '[', '' ), ']', '' ) AS ids ) t
转自:https://blog.csdn.net/pjymyself/article/details/81668157
https://www.cnblogs.com/gered/p/10797012.html#_label1
需求描述数据库中 num字段值为:实现的效果:需要将一行数据变成多行实现的sqlSELECT SUBSTRING_INDEX(SUBSTRING_INDEX('7654,7698,7782,7788',',',help_topic_id+1),',',-1) AS num FROM mysql.help_topic WHERE help_topic_id < LENGTH('7654,7698,7782,7788')-LENGTH(REPLACE('7654,7698,7782,.
下边的函数,实现了象数组一样去处理字符串。 一,用临时表作为数组 代码如下: create function f_split(@c varchar(2000),@split varchar(2)) returns @t table(col varchar(20)) as begin while(charindex(@split,@c)<>0) begin insert @t(col) values (substring(@c,1,charindex(@split,@c)-1)) set @c = stuff(@c,1,charindex(@split,@c),”) end insert @t
select distinct(substring_index(substring_index(a.col,',',b.help_topic_id+1),',',-1))
(select group_concat(
分割字符串为数组需要用到 三个mysql 的函数 :
REVERSE(str) 返回颠倒字符顺序的字符串str。
SUBSTRING_INDEX(str,delim,count)
返回从字符串str的第count个出现的分隔符delim之后的子串。如果count是正数,返回最后的分隔符到左边(从左边数) 的所有字符。如果count是负数,返回最后的分隔符到右边的所有字符(从右边数)。
REPLACE(str,from_str,to_str)
返回字符串str,其字符串from_str的所有出现由字符串to_str代替。
通过三个函数的组合使用做到分割字符串为数组的功能。
首先写两个函数
SUBSTRING_INDEX(SUBSTRING_INDEX(‘hud,wwe,rrt,tyf,oi’ ,’,’,i),’,’,-1) as id
(select ( @i := @i + 1) as i
test,
(select @i := 0) as it limit 15) num
where
num.i <= length(‘hud,wwe,rrt,tyf,oi’)-length(replace(‘hud,wwe,rrt,tyf,oi’ , ‘
SELECT
SUBSTRING_INDEX(SUBSTRING_INDEX('7654,7698,7782,7788',',',help_topic_id+1),',',-1) AS num
mysql.help_top...
在MySQL中,可以使用SUBSTRING_INDEX函数来拆分字符串。该函数的语法是SUBSTRING_INDEX(str, delim, count),其中str是要拆分的字符串,delim是分隔符,count是要返回的子字符串的数量。通过将help_topic_id与字符串长度和分隔符数量进行计算,可以模拟遍历并获取拆分后的子字符串。\[1\]
如果要判断外部值是否在拆分后的子字符串中,可以使用find_in_set或instr函数。find_in_set函数用于在逗号分隔的字符串中查找指定的值,而instr函数用于在字符串中查找指定的子字符串。这样可以判断外部值是否存在于拆分后的子字符串中。\[2\]
如果要进行无分隔符的字符串拆分,可以参考MySQL的字符串拆分(无分隔符的字符串截取)的方法。\[3\]
#### 引用[.reference_title]
- *1* *2* [MySql字符串拆分实现split功能(字段分割转列、转行)](https://blog.csdn.net/iijik55/article/details/126113522)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v4^insert_chatgpt"}} ] [.reference_item]
- *3* [mysql字符串拆分实现split功能](https://blog.csdn.net/weixin_30664615/article/details/97851845)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v4^insert_chatgpt"}} ] [.reference_item]
[ .reference_list ]