我的网站上有一个搜索字段功能,PHP 代码如下:
if(isset($_GET['search_ti']) && $_GET['search_ti'] != "")
{
$search_ti = preg_replace('#[^a-z 0-9?!-]#i', '', $_GET['search_ti']);
$sqlCommand = "
SELECT * FROM page WHERE title LIKE '%$search_ti%' OR body LIKE '%$search_ti%'
";
$result = $mysqli->query($sqlCommand) or die(mysql_error());
...
URL 变量search_ti
是我从 URL 中得到的搜索关键字。例如:
searchResult.php?search_ti=home
如果在我的 MySQL 表中找到关键字,则结果显示并且没有错误。
但如果找不到关键字,网络浏览器会生成以下错误:
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '-4,4' at line 1
我的代码有什么问题?
附加信息:
完整的 PHP 代码:http: //jsfiddle.net/eQSZc/
关键词:家。该错误仅在我的表中未找到该关键字时显示。