mysql字典表查询 GROUP_CONCAT 和 FIND_IN_SET 组合使用
程序员文章站
2024-03-23 09:02:04
...
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 组合使用
-
MySQL递归查询_函数语法检查_GROUP_CONCAT组合结果集的使用
-
使用SQL语句查询MySQL,SQLServer,Oracle所有数据库名和表名,字段名
-
emoji - thinkphp mysql 如何对指定表使用指定字符编码进行查询和操作?
-
mysql 查询表的行数和空间使用及其它信息_MySQL
-
emoji - thinkphp mysql 如何对指定表使用指定字符编码进行查询和操作?
-
mysql 查询表的行数和空间使用及其它信息_MySQL
-
使用SQL语句查询MySQL,SQLServer,Oracle所有数据库名和表名,字段名
-
MySQL递归查询_函数语法检查_GROUP_CONCAT组合结果集的使用