首页 >数据库 >mysql教程 >MySQL FIND_IN_SET() 与 IN():为什么 IN() 只返回第一个以逗号分隔的 ID 匹配项?

MySQL FIND_IN_SET() 与 IN():为什么 IN() 只返回第一个以逗号分隔的 ID 匹配项?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-12-11 10:40:12604浏览

MySQL FIND_IN_SET() vs IN(): Why Does IN() Only Return the First Match with Comma-Separated IDs?

FIND_IN_SET() 与 IN():了解 MySQL 中的差异

问题:

在 MySQL 中,我们有两个表:“orders”和“company”。 “orders”中的“attachedCompanyIDs”列存储引用“company”中行的逗号分隔的 ID 列表。当使用 FIND_IN_SET() 查询与订单关联的公司名称时,我们得到了预期的结果。但是,使用 IN() 仅返回第一个匹配的公司。为什么会发生这种情况?

答案:

attachedCompanyIDs 列是 VARCHAR 类型的标量值。当使用 IN() 时,MySQL 将字符串转换为整数,并在第一个非数字字符(即逗号)处截断它。这意味着如果attachedCompanyIDs包含多个值,则只会考虑第一个进行IN比较。

解决方法:

根据您的具体场景,有此问题的几种解决方法:

  1. 使用 ARRAY 类型 (PostgreSQL仅): PostgreSQL 支持数组数据类型,允许您将逗号分隔的列表存储为数组。这使您能够使用 ANY() 正确比较 AttachedCompanyIDs 中的值与 companyID 列。
  2. 有限值列表: 如果 AttachedCompanyIDs 中逗号分隔列表的长度有限,您可以使用一系列 UNION ALL 查询将字符串转换为多行。这允许您分别对每一行执行 IN 比较。

其他注意事项:

  1. 性能影响:使用 FIND_IN_SET() 可能会导致性能问题,尤其是对于大型数据集。使用上述替代解决方案可以提高这些场景中的性能。
  2. 可读性和维护:替代解决方案可能比使用 FIND_IN_SET() 更复杂且可读性更差。做出选择时请仔细考虑性能和可维护性之间的权衡。

以上是MySQL FIND_IN_SET() 与 IN():为什么 IN() 只返回第一个以逗号分隔的 ID 匹配项?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn