mysql 查询某字段中以逗号分隔的字符串的包含查询和关联查询实现

Posted 零度anngle

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql 查询某字段中以逗号分隔的字符串的包含查询和关联查询实现相关的知识,希望对你有一定的参考价值。

1、一个人员文件表结构和数据如下:

 

2、一个文件表,结构和数据如下:

需求一: 查询共同拥有file_id为3的用户

查询SQL:

select u.* from temp_user_file u  where FIND_IN_SET(3,u.file_id_str)

结果:

 需求二:关联查询用户所有file文件的名称和URL

查询sql:

SELECT t.user_id, f.id AS file_id, f.file_name, f.file_url FROM temp_user_file  t

LEFT JOIN temp_file f ON FIND_IN_SET(f.id,t.file_id_str)

结果:

       本人不建议在正式的大型项目中使用逗号分隔,存储数据,但往往有一些老项目或者遗留的表中存在类似的结构,如果实在不能新增表,只能扩展部分字段用以支持1对多关系,可参考。

以上是关于mysql 查询某字段中以逗号分隔的字符串的包含查询和关联查询实现的主要内容,如果未能解决你的问题,请参考以下文章

mysql 查询某字段中以逗号分隔的字符串的包含查询和关联查询实现

MYSQL查询某字段中以逗号分隔的字符串的方法

MYSQL语句,如果想搜索一个字段是不是包含某字符串应该怎么写

mysql 字段内容是用逗号分隔的。怎么按序列查询内容

mysql查询某数字在某字段以逗号隔开的字符里面

如何在 MySQL 的多对多关系中以逗号分隔的列表中的一个字段连接数据?