sys_user表里存了用户id,用户名,一个id一个用户名;meeting_record表里存了111,222.333.444类型的用户id,我要把meeting_record表里的用户id翻译成用户名;达梦数据库实现
时间: 2024-02-24 18:55:19 浏览: 62
Debug_sys.rar_ddk_debug.sys_sys debug
好的,那么在达梦数据库中,你可以使用以下 SQL 语句实现将 `meeting_record` 表格中的逗号分隔的用户 ID 字符串转换为逗号分隔的用户名字符串:
```sql
SELECT WMSYS.WM_CONCAT(u.user_name) AS user_names
FROM meeting_record m
JOIN sys_user u ON REGEXP_LIKE(m.user_ids, '(^|,)' || u.user_id || '(,|$)')
WHERE m.meeting_id = 123;
```
其中,`sys_user` 表格是存储用户名和用户 ID 的表格,`meeting_record` 表格是存储会议记录的表格,`user_ids` 是存储逗号分隔的用户 ID 字符串的列名,`meeting_id` 是会议记录的 ID。
这个 SQL 语句使用了 `REGEXP_LIKE` 函数和正则表达式来实现查找逗号分隔的用户 ID 字符串中是否包含指定的用户 ID。`WMSYS.WM_CONCAT` 函数可以将查询结果中的多个用户名连接成一个字符串,使用逗号分隔。最后通过 `WHERE` 子句指定要查询的会议记录的 ID。
你可以将 `123` 替换成需要查询的会议记录的 ID,然后执行这个 SQL 语句就可以得到逗号分隔的用户名字符串。
阅读全文