MYSQL 按分隔符,一分多
时间: 2023-08-22 12:14:40 浏览: 97
你的问题不太清楚,不过我猜你可能想问的是,MySQL中按照分隔符分割字符串时,如果分隔符在字符串中出现了多次,该如何处理?
如果你用的是MySQL 8.0及以上版本,你可以使用REGEXP_SPLIT_TO_TABLE函数来按照分隔符分割字符串。该函数使用正则表达式作为分隔符,因此你可以使用正则表达式中的特殊符号来指定分隔符。例如,下面的示例将字符串按照逗号分隔:
```
SELECT * FROM REGEXP_SPLIT_TO_TABLE('a,b,c,d,e', ',');
```
该查询的结果为:
```
+------+
| value|
+------+
| a |
| b |
| c |
| d |
| e |
+------+
```
如果分隔符在字符串中出现多次,该函数会将其视为一个分隔符。例如,下面的示例将字符串按照连续的逗号分隔:
```
SELECT * FROM REGEXP_SPLIT_TO_TABLE('a,,b,c,d,e', ',');
```
该查询的结果为:
```
+------+
| value|
+------+
| a |
| |
| b |
| c |
| d |
| e |
+------+
```
注意到中间的两个逗号被视为一个分隔符,并且生成了一个空字符串。
如果你使用的是MySQL 5.7及以下版本,你可以使用SUBSTRING_INDEX函数来按照分隔符分割字符串。该函数接受三个参数:要分割的字符串、分隔符和要返回的子串在整个字符串中的位置。例如,下面的示例将字符串按照逗号分隔:
```
SELECT SUBSTRING_INDEX('a,b,c,d,e', ',', 1) AS part1,
SUBSTRING_INDEX(SUBSTRING_INDEX('a,b,c,d,e', ',', 2), ',', -1) AS part2,
SUBSTRING_INDEX(SUBSTRING_INDEX('a,b,c,d,e', ',', 3), ',', -1) AS part3,
SUBSTRING_INDEX(SUBSTRING_INDEX('a,b,c,d,e', ',', 4), ',', -1) AS part4,
SUBSTRING_INDEX(SUBSTRING_INDEX('a,b,c,d,e', ',', 5), ',', -1) AS part5;
```
该查询的结果为:
```
+-------+-------+-------+-------+-------+
| part1 | part2 | part3 | part4 | part5 |
+-------+-------+-------+-------+-------+
| a | b | c | d | e |
+-------+-------+-------+-------+-------+
```
注意到SUBSTRING_INDEX函数的第三个参数可以是正数或负数。如果是正数,则表示要返回的子串在原字符串中出现的位置,从左到右数;如果是负数,则表示要返回的子串在原字符串中出现的位置,从右到左数。因此,上面的查询使用了负数来获取每个子串在原字符串中的最后一个位置。
阅读全文