从 MySQL 数据库检索数据时,通常需要以特定的方式对结果进行排序顺序。 IN() 方法可用于根据预定义的值列表检索记录,但是当您想要维护结果集中 IN() 子句中的值的顺序时,就会出现挑战。
问题:
假设您有一个包含有序 ID 号的 PHP 数组,并且想要使用 IN() 方法从 MySQL 表中获取相应的记录。但是,您需要按照 IN() 子句中指定的顺序返回这些记录。
解决方案:
可以解决此问题的强大函数挑战是FIELD()。它主要被称为字符串函数,但它也可以有效地处理数字数据。通过使用FIELD(),您可以指定IN()子句中值的所需顺序,MySQL将相应地排列结果。
示例:
让我们考虑以下带有有序 ID 号的 PHP 数组:
$ids = [4, 7, 3, 8, 9];
从名为articles的表中检索相应的记录,同时保持顺序对于 ID,您可以使用以下 MySQL 查询:
SELECT * FROM articles ORDER BY FIELD(id, 3, 2, 5, 7, 8, 1);
在此查询中,FIELD() 函数用于根据第二个参数中的值的顺序对结果进行排序。 IN() 子句中指定的顺序是 [4, 7, 3, 8, 9],但我们希望返回结果为:3, 2, 5, 7, 8, 1。因此,我们提供值按照严格的顺序作为 FIELD() 的第二个参数。这可确保文章按所需顺序返回。
以上是如何使用 IN() 和 FIELD() 按自定义顺序对 MySQL 查询结果进行排序?的详细内容。更多信息请关注PHP中文网其他相关文章!