首页 >数据库 >mysql教程 >MySQL 中的 FIND_IN_SET() 与 IN():我什么时候应该使用它们?

MySQL 中的 FIND_IN_SET() 与 IN():我什么时候应该使用它们?

Barbara Streisand
Barbara Streisand原创
2024-12-18 04:12:15633浏览

FIND_IN_SET() vs. IN() in MySQL: When Should I Use Each?

Find_in_set() 与 IN():了解差异

在 MySQL 中,FIND_IN_SET() 和 IN() 运算符起着至关重要的作用从表中查询数据。虽然两者都可以用于测试一组值中的成员资格,但它们在处理特定场景的方式上有所不同。

考虑以下查询,其旨在检索与订单关联的公司名称:

SELECT name
FROM orders, company
WHERE orderID = 1 AND FIND_IN_SET(companyID, attachedCompanyIDs)

此查询成功生成所有三个公司名称:Company 1、Another Company 和 StackOverflow。但是,如果我们将 FIND_IN_SET() 替换为 IN(),结果会出乎意料:

SELECT name
FROM orders, company
WHERE orderID = 1 AND companyID IN (attachedCompanyIDs)

在这种情况下,仅返回第一个公司名称 Company 1。要理解原因,必须掌握这些运算符的基本机制。

FIND_IN_SET()

FIND_IN_SET() 对逗号内的特定值执行文字搜索- 分隔的字符串。在本例中,attachedCompanyIDs 包含类似“1,2,3”的字符串。 FIND_IN_SET() 返回目标值(1、2 或 3)在此字符串中的位置,如果未找到,则返回 0。

IN()

IN另一方面,() 期望将值列表与目标值进行比较。但是,在 MySQL 中,attachedCompanyIDs 是标量值,而不是数组或列表。因此,MySQL 尝试将此标量字符串转换为整数(companyID 的类型)以进行 IN() 比较。

在转换过程中,MySQL 解释字符串中的第一个逗号 ('1,2,3' ) 作为数字部分的结尾,导致整数值为 1。本质上,IN() 条件实际上变为:

companyID IN (1)

这解释了为什么只有第一家公司检索到名称“公司 1”。 IN() 条件仅对于逗号分隔字符串中的第一个值成立。

解决方案

如果假设成立逗号中的值的数量- 分隔的列表是有限的,可以采用其他方法来有效地处理此类情况。

以上是MySQL 中的 FIND_IN_SET() 与 IN():我什么时候应该使用它们?的详细内容。更多信息请关注PHP中文网其他相关文章!

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