【问题标题】:PHP - MYSQL fulltext searchPHP - MYSQL 全文搜索
【发布时间】:2012-01-16 02:32:59
【问题描述】:

我有一个 MYSQL 全文搜索,与我的数据库中的项目匹配,效果很好。

$select = "SELECT * from menu WHERE MATCH(item) AGAINST('$this->food') ";

从那里我根据用户想要过滤的内容细化查询。我有 2 个过滤器,vegetarian 和 breadtype

   if(isset($this->vegetarian)) { 
      echo $select .= " AND vegetarian='$this->vegetarian'"; 
    }

   if(isset($this->bread)) { 
       echo $select .= " AND bread='$this->bread'";
   }

它附加了全文语句,现在它完美地工作了,虽然我的问题是 如果用户不搜索任何内容(空字符串),我希望它返回数据库中的所有结果。

 if(empty($this->food)) { $select = "SELECT * from menu"; }

这意味着我不能将 $select 语句附加到上面的 if 语句中,而必须使用 WHERE 语句 - 但这意味着添加 2 个额外的 if 语句来弥补这一点。无论如何,MYSQL 是否可以这样做。

 if(isset($this->vegetarian) && empty($this->food)) { 
      echo $select .= " WHERE vegetarian=$this->vegetarian"; 
    }

【问题讨论】:

  • 我只接受正确答案。

标签: php mysql full-text-search


【解决方案1】:

您可以简单地使用WHERE 1=1,然后附加其余部分。如果没有额外的ANDs 或ORs,MySQL 将直接忽略这部分。

【讨论】:

  • 啊,太棒了,非常感谢。我会尽快接受你的回答:)
【解决方案2】:
$select = "SELECT * from menu WHERE MATCH(item) AGAINST('$this->food') ";
if(empty($this->food)) {
  $select = "SELECT * from menu WHERE 1=1"; // if food is empty we overwrite the $select variable
} else {
    if(isset($this->vegetarian)) { 
      $select .= " AND vegetarian='$this->vegetarian'"; 
    }

    if(isset($this->bread)) { 
      $select .= " AND bread='$this->bread'";
    }
}

还是我错过了什么?

【讨论】:

  • 感谢这个答案也是我想要的。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2010-10-22
  • 2015-07-03
  • 1970-01-01
  • 2010-10-30
  • 1970-01-01
相关资源
最近更新 更多