我试图查询数据库以查找单独表中两列之间的相关结果,为此我使用以下代码:
$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语法中有错误,但我不确定它是什么,有什么指针?
答案 0 :(得分:2)
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()
);
答案 1 :(得分:0)
有时即使语法正确,也会出现此错误,因为某些SQL版本不支持此语法。
在查看其他方法之前,请确保您的MySQL版本支持此查询。