0

我正在编写一个用于高级搜索的 PHP 脚本,但发生了错误。请帮助
代码:

$key    = $_GET['key'];
$auth   = $_GET['auth'];
$lang   = $_GET['lang'];
$pub    = $_GET['pub'];

if(isset($key) OR isset($auth) OR isset($lang) OR isset($pub))
{
    if ($key    != NULL){$keyword   = "AND (native_name LIKE '%".$key."%' OR unique_name LIKE '%".$key."%')";}
    if ($auth   != 0)   {$auther    = "AND auth_id=".$auth."";}
    if ($lang   != 0)   {$language  = "AND lang_id=".$lang."";}
    if ($pub    != 0)   {$publisher = "AND pub_id=".$pub."";}

    $search_query = "SELECT native_name from books WHERE status=1 ".$keyword." ".$auther." ".$language." ".$publisher."";
    print $search_query;
}

错误:

注意:未定义变量:第 90 行 FILE_PATH 中的关键字
注意:未定义变量:第 90 行 FILE_PATH 中的 auther 注意:未定义变量:第 90
行 FILE_PATH 中的语言
注意:未定义变量:第 90 行 FILE_PATH 中的发布者

4

2 回答 2

1

如果您通过 if 语句创建变量,则可能不会创建这些变量。

您的情况有几种不同的选择。

1、使用三元语法

$keyword = $key != NULL ? "AND (native_name LIKE '%".$key."%' OR unique_name LIKE '%".$key."%')" : "";
$author = $auth !=0 ? "AND auth_id=".$auth : "";
$language = $lang !=0 ? "AND lang_id=".$lang : "";
$publisher = $pub !=0 ? "AND pub_id=".$pub : "";

2、预定义变量

$keyword = "";
$author = "";
$language = "";
$publisher = "";

if ($key    != NULL){$keyword   = "AND (native_name LIKE '%".$key."%' OR unique_name LIKE '%".$key."%')";}
if ($auth   != 0)   {$auther    = "AND auth_id=".$auth."";}
if ($lang   != 0)   {$language  = "AND lang_id=".$lang."";}
if ($pub    != 0)   {$publisher = "AND pub_id=".$pub."";}
于 2012-11-14T18:32:56.820 回答
0

$keyword/$auther/etc.. 仅在设置了 _POST 中的相应值时才被分配。如果没有传入数据,$key/$auth/etc...将为空字符串或null,等于0/null。尝试:

if ($key != null) {
   $keyword = ...;
} else {
   $keyword = some default value;
}

其他的也是如此。

于 2012-11-14T18:28:53.247 回答