首页 > 后端开发 > php教程 > 如何高效查询包含逗号分隔值的数据库列?

如何高效查询包含逗号分隔值的数据库列?

Barbara Streisand
发布: 2024-12-30 21:44:10
原创
808 人浏览过

How Can I Efficiently Query a Database Column Containing Comma-Separated Values?

处理单列中包含多个值的查询

在这种情况下,我们遇到一个表,其中包含名为“children”的列,该列存储以逗号分隔的名称。目标是检索此列中存在指定子项(例如“Alex”)的记录。

但是,使用简单的相等性检查(例如“WHERE Children = 'Alex'”)会失败,因为有多个名称存在于每个细胞中。基本的 LIKE 搜索(“WHERE kids LIKE '%Alex%'”)会因部分匹配(例如“Alexandre”或“Diana”)而导致误报。

为了解决这一挑战,最佳方法是通过引入单独的表来存储子父关系来标准化数据结构。这将使我们能够有效地执行连接并检索所需的信息。

尽管如此,如果规范化不可行,则会提出使用 FIND_IN_SET 函数的解决方案:

WHERE FIND_IN_SET('Alex', children) > 0
登录后复制

此函数搜索列值中的指定字符串,如果该字符串存在,则返回正数。通过将此条件合并到 WHERE 子句中,我们可以识别列出“Alex”子项的行。

以上是如何高效查询包含逗号分隔值的数据库列?的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板