mysql把逗号隔开的字符串拆分
时间: 2023-08-27 17:15:28 浏览: 43
如果你需要将一个逗号隔开的字符串拆分成多个值,可以使用 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'。你可以将这个查询作为一个子查询,将其结果与其他表进行联接,或者按照需要进行进一步处理。
相关问题
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 的 FIND_IN_SET() 函数和 REPLACE() 函数将其拆分成单个数字,并使用 SUM() 函数将它们求和。具体步骤如下:
首先,使用 REPLACE() 函数将逗号替换为空格,然后使用 TRIM() 函数删除空格:
```
SELECT TRIM(REPLACE('1,2,3,4,5', ',', ' '));
```
然后,使用 FIND_IN_SET() 函数将字符串中的每个数字拆分成单独的行:
```
SELECT FIND_IN_SET('1 2 3 4 5', '1');
```
最后,使用 SUM() 函数对拆分后的数字进行求和:
```
SELECT SUM(FIND_IN_SET('1 2 3 4 5', '1'));
```
或者将其组合成一个查询:
```
SELECT SUM(FIND_IN_SET(TRIM(REPLACE('1,2,3,4,5', ',', ' ')), '1'));
```
这将返回数字字符串中所有值为 1 的数字的总和。如果要计算其他数字的总和,只需将函数中的 '1' 替换为所需的数字即可。