mysql把逗号隔开的字符串分割
时间: 2023-10-12 21:01:05 浏览: 127
如果你需要将一个逗号隔开的字符串分割成多个值并返回一个结果集,可以使用 MySQL 中的内置函数 `SUBSTRING_INDEX()` 和 `UNION ALL` 运算符。下面是一个示例查询:
```
SELECT SUBSTRING_INDEX(SUBSTRING_INDEX('apple,banana,orange', ',', n.digit+1), ',', -1) AS fruit
FROM
(SELECT 0 digit UNION ALL SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3) n
WHERE
n.digit < LENGTH('apple,banana,orange') - LENGTH(REPLACE('apple,banana,orange', ',', '')) + 1
```
这将返回一个包含拆分后每个值的行集合。在这个示例中,我们将字符串 'apple,banana,orange' 分割成三个部分:'apple'、'banana' 和 'orange'。你可以将这个查询作为一个子查询,将其结果与其他表进行联接,或者按照需要进行进一步处理。
如果你想将分割后的值以多行的形式返回,可以使用 `UNION ALL` 运算符连接多个 `SELECT` 语句,每个 `SELECT` 语句返回一个值。下面是一个示例查询:
```
SELECT SUBSTRING_INDEX(SUBSTRING_INDEX('apple,banana,orange', ',', n.digit+1), ',', -1) AS fruit
FROM
(SELECT 0 digit UNION ALL SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3) n
WHERE
n.digit < LENGTH('apple,banana,orange') - LENGTH(REPLACE('apple,banana,orange', ',', '')) + 1
UNION ALL
SELECT SUBSTRING_INDEX(SUBSTRING_INDEX('grape,pear,melon', ',', n.digit+1), ',', -1) AS fruit
FROM
(SELECT 0 digit UNION ALL SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3) n
WHERE
n.digit < LENGTH('grape,pear,melon') - LENGTH(REPLACE('grape,pear,melon', ',', '')) + 1
```
在这个示例中,我们使用两个 `SELECT` 语句分别处理两个逗号隔开的字符串,然后使用 `UNION ALL` 运算符将它们的结果集合并成一个结果集。
阅读全文