mysql字典表查询 GROUP_CONCAT 和 FIND_IN_SET 组合使用
两表联查,但其中一个字段有多个值并且使用“,”隔开
用户表 和 字典表
其中用户表中的code字段对应字典表中的code

需要查询用户列表并且code类型已文字方式展现
SELECT
(select GROUP_CONCAT(c.text) from codes c where FIND_IN_SET(c.code,u.`code`)),
u.user_name
FROM `users` u
查询结果

FIND_IN_SET函数简介
MySQL提供了一个名为FIND_IN_SET()的内置字符串函数,允许您在逗号分隔的字符串列表中查找指定字符串的位置。
下面说明了FIND_IN_SET()函数的语法。
FIND_IN_SET(needle,haystack);
FIND_IN_SET()函数接受两个参数:
- 第一个参数needle是要查找的字符串。
- 第二个参数haystack是要搜索的逗号分隔的字符串列表。
FIND_IN_SET()函数根据参数的值返回一个整数或一个NULL值:
- 如果needle或haystack为NULL,则函数返回NULL值。
- 如果needle不在haystack中,或者haystack是空字符串,则返回零。
- 如果needle在haystack中,则返回一个正整数。

本文介绍如何在MySQL中使用GROUP_CONCAT和FIND_IN_SET函数进行两表联查,特别适用于字段值由逗号分隔的情况。通过具体实例,展示了如何将用户表与字典表关联,实现code字段的文本展示。
721

被折叠的 条评论
为什么被折叠?



