我尝试查询数据库以查找单独表中两列之间的相关结果,为此,我使用以下代码:
$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版本是否支持此查询。