”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 如何在 MySQL WHERE IN() 子句中处理具有多个值的记录?

如何在 MySQL WHERE IN() 子句中处理具有多个值的记录?

发布于2024-12-23
浏览:171

How to Handle Records with Multiple Values in a MySQL WHERE IN() Clause?

MySQL IN () 运算符

查询 MySQL 数据库时,WHERE IN () 运算符常用于根据特定条件检索行列中的值。例如,以下查询从“table”表中检索“id”列与任意值 (1、2、3、4) 匹配的所有行:

SELECT * FROM table WHERE id IN (1,2,3,4);

但是,当一条记录具有多个“id”值(例如 1 和 3)时,就会出现问题。在这种情况下,查询可能不会返回该行。

解决方案

查询转换为以下 OR 条件:

SELECT * FROM table WHERE id='1' or id='2' or id='3' or id='4';

因此,它只会返回符合以下条件的行:匹配这些条件中的任何一个。

要解决此问题,一种选择是对“id”列使用 SET 数据类型。这允许您使用逗号分隔的字符串存储多个值。然后,您可以使用 FIND_IN_SET() 函数搜索特定值:

SELECT * FROM table WHERE FIND_IN_SET('1', id);

此查询将返回所有行将“1”作为“id”列中的值之一,而不管可能存在的任何其他值。

最新教程 更多>

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3