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中文网其他相关文章!