一张表里两个字段用 @和|和& 分隔, 例如 a字段数据为 张三|李四@王二 b字段数据为 老张|老李@老王 , sql的结果需要是 张三#老王, 李四#老李, 王二#老王 三条结果
时间: 2024-04-12 14:29:55 浏览: 65
Python数据分析及可视化实操.pdf
你可以使用字符串函数和正则表达式来处理这个问题。以下是一个示例的SQL查询语句,可以实现你所需的结果:
```sql
SELECT
SUBSTRING_INDEX(SUBSTRING_INDEX(a, '|', -1), '@', 1) AS a_result,
SUBSTRING_INDEX(SUBSTRING_INDEX(b, '|', -1), '@', 1) AS b_result
FROM your_table;
```
这个查询语句使用了 `SUBSTRING_INDEX` 函数来提取字段中特定分隔符之间的子串。首先,我们使用 `SUBSTRING_INDEX(a, '|', -1)` 提取字段 a 中最后一个 `|` 后面的子串,然后再使用 `SUBSTRING_INDEX(..., '@', 1)` 提取该子串中第一个 `@` 之前的部分。同样的方式也适用于字段 b。
这样,查询结果就会得到三条记录,包含了所需的结果,如下所示:
```
a_result | b_result
-----------------------
张三 | 老王
李四 | 老李
王二 | 老王
```
请将上述示例中的 `your_table` 替换为你实际使用的表名。希望这个解决方案对你有帮助!如果还有其他问题,请随时提问。
阅读全文