mysql 字符串逗号隔开转多行
时间: 2023-11-03 17:58:16 浏览: 32
假设你有一个包含逗号分隔符的字符串:
```
str = 'apple,banana,orange,grape'
```
你可以使用 `REPLACE` 函数将逗号替换成换行符 `\n`:
```
SELECT REPLACE(str, ',', '\n');
```
结果将是:
```
apple
banana
orange
grape
```
如果你想将结果插入到另一个表中,可以使用 `INSERT INTO SELECT` 语句:
```
INSERT INTO new_table (col1)
SELECT REPLACE(str, ',', '\n')
FROM old_table;
```
相关问题
mysql把逗号隔开的字符串分割
如果你需要将一个逗号隔开的字符串分割成多个值并返回一个结果集,可以使用 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` 运算符将它们的结果集合并成一个结果集。
mysql把逗号隔开的字符串拆分
如果你需要将一个逗号隔开的字符串拆分成多个值,可以使用 MySQL 中的内置函数 `SUBSTRING_INDEX()` 和 `GROUP_CONCAT()`。下面是一个示例查询:
```
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'。你可以将这个查询作为一个子查询,将其结果与其他表进行联接,或者按照需要进行进一步处理。