mysql字符串逗号分隔查询

admin 轻心小站 关注 LV.19 运营
发表于数据库技术学习版块 mysql

在MySQL中,查询字符串中的逗号分隔值是一个非常常见的需求。比如,在某个字段中保存了一些逗号分隔的数据,我们需要查询包含某个特定值的记录。这时候,我们可以使用MySQL的“FIND_IN_SET()

在MySQL中,查询字符串中的逗号分隔值是一个非常常见的需求。比如,在某个字段中保存了一些逗号分隔的数据,我们需要查询包含某个特定值的记录。这时候,我们可以使用MySQL的“FIND_IN_SET()”函数来实现。

SELECT * FROM table_name WHERE FIND_IN_SET('要查找的值', 字段名) > 0;

在上面的代码中,“FIND_IN_SET()”函数的第一个参数是要查找的值,第二个参数是字段名。如果“FIND_IN_SET()”函数返回的值大于0,说明该记录中包含要查找的值。

如果我们需要查询包含多个特定值的记录,也可以用同样的方法实现。只需要简单地将多个要查找的值用逗号隔开即可。

SELECT * FROM table_name WHERE FIND_IN_SET('要查找的值1', 字段名) > 0 AND FIND_IN_SET('要查找的值2', 字段名) > 0;

需要注意的是,使用“FIND_IN_SET()”函数来查询逗号分隔的值在性能上并不高,特别是数据量很大的时候。如果可能的话,应当避免使用逗号分隔的数据,而是使用关联表来保存多个值。

综上所述,查询逗号分隔的值是MySQL中一项常见的任务。虽然可以使用“FIND_IN_SET()”函数来实现,但是在性能上并不高。因此,尽可能避免使用逗号分隔的数据,使用关联表来保存多个值。

文章说明:

本文原创发布于探乎站长论坛,未经许可,禁止转载。

题图来自Unsplash,基于CC0协议

该文观点仅代表作者本人,探乎站长论坛平台仅提供信息存储空间服务。

评论列表 评论
发布评论

评论: mysql字符串逗号分隔查询

粉丝

0

关注

0

收藏

0

已有0次打赏