按特定顺序选择特定行

我有一个脚本(在 PHP 中),它通过一系列不同的比较来生成表中按行 ID 排序的条目数组。然后我将数组内爆成一个字符串并使用 WHERE 选择那些特定的行,但是我不知道如何按照它们在数组中的相同顺序对它们进行排序。


$order_array = [50,49,42,52,53,54,51,48,47]

$order_string = implode(',', $order_array);

// echo $order_string returns '50,49,42,52,53,54,51,48,47'

$sql_todo = "SELECT * FROM todo_list WHERE id IN ({$order_string})";

    if ($result_todo = mysqli_query($link, $sql_todo)) {

        while ($row_todo = mysqli_fetch_assoc($result_todo)) {

这成功地选择了所需的行,但它们与数组的顺序不同。我知道我没有告诉它以这种方式订购它们(所以它没有),但我不知道如何实现它。


谢谢你的时间,


慕斯王
浏览 110回答 1
1回答

RISEBY

您可以使用以下field()功能:"SELECT * FROM todo_list WHERE id IN ({$order_string}) ORDER BY FIELD(id, {$order_string})"field()返回其第一个参数在列表中的索引,您可以直接将其用于排序。旁注:您可能应该使用准备好的语句而不是在查询字符串中连接值(如果您的值来自代码外部,这是必须的)。
打开App,查看更多内容
随时随地看视频慕课网APP