对这些术语查询使用 ORDER BY


use ORDER BY to these term queries

right,我有两个查询可以扫描MYSQL数据库中的关键字并返回它们,无论它们是a)在一起还是b)分开。我现在添加了一个名为"rank"的新列,按顺序对它们进行排名。我为每个查询添加了"ORDER BY rank",当我输入单个术语时,结果会正确显示,但是当输入两个或更多术语时,我会收到此错误: MySQL 查询错误:您的 SQL 语法有错误;检查与您的MySQL服务器版本相对应的手册,了解在第1行的"ORDER BYRANK"附近使用的正确语法。 结果按 id 自动排名。当我从一个查询中删除 ORDER BY 标签时,另一个查询的标签将不起作用。我不明白吗?我的查询如下。

    // Terms Together
    $query = " SELECT * FROM scan WHERE "; 
$terms = array_map('mysql_real_escape_string', $terms);
$i = 0; 
foreach ($terms as $each) {
      if ($i++ !== 0){
            $query .= " AND ";
      }
      $query .= "keywords LIKE '%{$each}%' ORDER BY rank";
}
            /* Query Statement Building - Terms Separate */
    $query = " SELECT * FROM scan WHERE "; 
    $terms = array_map('mysql_real_escape_string', $terms);
    $i = 0; 
    foreach ($terms as $each) {
          if ($i++ !== 0){
                $query .= " OR "; 
          }
          $query .= "keywords LIKE '%{$each}%' ORDER BY rank";
    }

ORDER BY必须位于循环的末尾,而不是循环内部。否则,每个查询会得到多个 ORDER BY 语句,这是无效的:

foreach ($terms as $each) {
      if ($i++ !== 0){
            $query .= " OR "; 
      }
      $query .= "keywords LIKE '%{$each}%'";
}
// Don't append the ORDER BY until after the loop
$query .= " ORDER BY rank";

更改两个循环以使用此模式,而不是当前拥有的模式。