背景:我们在做数据分析,或者数据分组时经常会遇到一种如下情况

这里的‘66,51,90,91,93’往往需要进行数据匹配查出对应的值,在java代码只要用split即可实现,而在mysql中则需要使用SUBSTRING_INDEX方法。
实现方法:
SELECT
ss.id,
ss.`name`,
ss.material_cost,
ss.third_party_platform_service_fee,
ss.vat,
SUBSTRING_INDEX( SUBSTRING_INDEX( ss.store_id_str, ',', i.id ), ',',- 1 ) AS num
FROM
edw.bi_store_set ss,
edw.bi_id_index i
WHERE
i.id - 1 < LENGTH( ss.store_id_str )- LENGTH(
REPLACE ( ss.store_id_str, ',', '' ))+ 1
代码解释:这里是利用结果集里的字符串长度对字符串进行切割,edw.bi_id_index i是我自设的一个索引长度,里面存放数据如下:

建议你的最大值尽可能的长并且要连续。
很多搜素结果给的是使用
mysql自带的一个表里的id但有时候在生产上会受到权限限制等。所以建议使用自己建的一个自增id。
结果:


本文详细介绍了在MySQL中如何使用SUBSTRING_INDEX函数处理字符串,特别是在数据分析和数据分组场景下,如何通过该函数实现类似Java中的split效果。文中提供了一个具体的SQL查询示例,展示了如何根据自定义的索引长度对字符串进行切割,并给出了创建自增ID索引表的建议,以避免依赖系统内置表可能带来的权限问题。
323

被折叠的 条评论
为什么被折叠?



