mysql字典表查询 GROUP_CONCAT 和 FIND_IN_SET 组合使用

版权声明:博客对我来说是记忆的笔记和知识的分享~非常感谢博客大神的帮助,若有无意侵权,请您联系我,谢谢^_^!转载请声明出处: https://blog.csdn.net/qq_36698956/article/details/89306638

两表联查,但其中一个字段有多个值并且使用“,”隔开

用户表 和 字典表

其中用户表中的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中,则返回一个正整数。

猜你喜欢

转载自blog.csdn.net/qq_36698956/article/details/89306638