MySQL split与正则表达式结合

avatar
作者
筋斗云
阅读量:0

在MySQL中,可以使用正则表达式结合SUBSTRING_INDEX函数来实现split的功能。下面是一个示例:

假设有一个表users,其中有一个字段name包含了多个值,这些值之间用逗号进行分隔,现在需要将这些值拆分出来。

SELECT     SUBSTRING_INDEX(SUBSTRING_INDEX(name, ',', n), ',', -1) AS split_value FROM     users,     (SELECT 1 AS n UNION ALL SELECT 2 UNION ALL SELECT 3) numbers WHERE     n <= LENGTH(name) - LENGTH(REPLACE(name, ',', '')) + 1; 

上面的SQL语句中,首先使用REPLACE函数计算出字段name中逗号的数量,然后使用LENGTH函数计算出需要拆分的值的数量。接着使用SUBSTRING_INDEX函数和一个子查询numbers将字段name中的值拆分出来。

通过这种方式,就实现了在MySQL中使用正则表达式结合SUBSTRING_INDEX函数来实现split的功能。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!