使用 MATCH () AGAINST STAT() 时的 MYSQL 语法错误


MYSQL syntax error while using MATCH () AGAINST()

我尝试查询数据库以查找单独表中两列之间的相关结果,为此,我使用以下代码:

$query = "SELECT * FROM $table WHERE MATCH (TITLE) AGAINST ($description) AND ARTIST=$band ORDER BY relevance DESC";
    $result = mysql_query($query);
    if (!$result) {
        die("Result False on line 47: $result <br>
            Query: $query <br>
            Error: " . mysql_error());
    }

正如您可能期望的那样,出现错误消息说我的 MYSQL 语法有错误,但我不确定它是什么,有什么指示吗?

AGAINST ($description)应该AGAINST ('$description')

ARTIST=$band应该ARTIST='$band'

通过查询处理的任何字符串都需要用单引号 ( ' ) 括起来,带空格的列名需要反引号 ( ' )。

如果$description$band包含任何引号或斜杠,则需要使用 mysql_real_escape_string() 对其进行转义(无论如何我都建议这样做)

此外,还可以将die语句合并到查询行中:

$result = mysql_query($query) or die(
"Result False on line 47: $result <br>
            Query: $query <br>
            Error: " . mysql_error()
);

有时甚至语法是正确的,此错误即将到来,因为某些SQL版本不支持此语法。

在研究其他方法之前,请确保您的MySQL版本是否支持此查询。