在 MySQL“IN”查询中保留顺序
在 MySQL 中,“IN”查询结果中的行顺序通常与主键或任何定义的索引。但是,此行为可能不遵守查询中指定的顺序。要保留所需的顺序,请考虑以下解决方案:
使用 FIELD() 进行自定义排序:
FIELD() 函数计算给定值在以逗号分隔的值列表。通过在 ORDER BY 子句中使用此函数,您可以指定所需的结果顺序。例如:
SELECT * FROM foo f WHERE f.id IN (2, 3, 1) ORDER BY FIELD(f.id, 2, 3, 1);
在此修改后的查询中,FIELD() 的参数列表表示所需的顺序:2、3 和 1。因此,结果将按以下顺序显示:
id | name |
---|---|
2 | second |
3 | third |
1 | first |
与原始查询不同,此修改保证了指定的顺序,在从表中检索数据时提供更大的灵活性并确保结果与您的匹配期待。
以上是如何保证 MySQL IN 查询的顺序?的详细内容。更多信息请关注PHP中文网其他相关文章!