PHP SQL SELECT where like search item with multiple words

Posted

技术标签:

【中文标题】PHP SQL SELECT where like search item with multiple words【英文标题】: 【发布时间】:2011-04-06 23:38:09 【问题描述】:

我有一个 select where like 查询表单,如下所示:

<?php 
$bucketsearch = sanitizeone($_POST["bucketsearch"], "plain");
$bucketsearch = strip_word_html($bucketsearch);
?>

 if(isset($_POST['search']))
                  $result=mysql_QUERY( "SELECT * FROM buckets where bucketname like '%$bucketsearch%' order by bucketname");
              else
              $result=MYSQL_QUERY( "SELECT * FROM buckets order by bucketname");
          

我的问题是,如果有人搜索例如“apple and pear”,我没有得到任何包含任何单词的结果,我只能让它返回包含所有单词的结果(以及 1 个结果)。

谁能帮我让这个搜索更通用一点? 提前致谢。

【问题讨论】:

【参考方案1】:

所以您想要使用输入的每个单词而不是确切的字符串进行 AND 搜索?这样的事情怎么样:

$searchTerms = explode(' ', $bucketsearch);
$searchTermBits = array();
foreach ($searchTerms as $term) 
    $term = trim($term);
    if (!empty($term)) 
        $searchTermBits[] = "bucketname LIKE '%$term%'";
    


...

$result = mysql_query("SELECT * FROM buckets WHERE ".implode(' AND ', $searchTermBits).");

这会给你一个类似的查询:

SELECT * FROM buckets WHERE bucketname LIKE '%apple%' AND bucketname LIKE '%and%' AND bucketname LIKE '%pear%'

如果您想匹配任何搜索词而不是全部,请将 AND 更改为 OR。进一步的改进可能包括定义一些停用词,如“和”,以提供更好的结果。

【讨论】:

蒂姆,谢谢!我玩了大约 30 分钟,我复制了我的页面来测试它,无法弄清楚为什么它不起作用,对所有内容进行了大量检查,然后意识到 Dreamweaver 在我的输入末尾添加了“2”姓名!!!呸。我将其更改为 OR,它实现了一个梦想!谢谢你。现在就去寻找一个删除停用词的功能。谢谢您的帮助!! :) 对于任何阅读此内容的 laravel ppl,请查看:gist.github.com/clouddueling/4967617 我只想补充一点,当使用 OR 模式时,必须将整个查询条件括在括号 () 中,因为可能会发生意外结果(尽管您不会知道,因为每次都不会出现 MySQL 错误瑟)。我从不相关的类别中得到结果,即使在单独的 AND 条件中指定了特定类别。例如,在 Tim 的回答中替换上述内容: implode(' OR ', $searchTermBits) 部分为 '(' . implode(' OR ', $searchTermBits) . ')'【参考方案2】:

我认为最好的解决方案是使用正则表达式。它是最干净的,可能也是最有效的。所有常用的数据库引擎都支持正则表达式。

在 MySQL 中有 RLIKE 运算符,因此您的查询将类似于:

SELECT * FROM buckets WHERE bucketname RLIKE "(?=.*apple)(?=.*and)(?=.*pear)"

没有测试,希望我的表达方式适合MySQL正则表达式“方言”。

有关 MySql 正则表达式支持的更多信息:http://dev.mysql.com/doc/refman/5.1/en/regexp.html#operator_regexp

【讨论】:

【参考方案3】:

对于您的简单案例,您可以将“and”替换为“%”(但我猜您正在寻找更全面的答案。(这也是特定于订单的,因为苹果必须在梨之前。)

【讨论】:

【参考方案4】:

呃。这不是我认为的最佳解决方案,但您可以将单词分解成一个数组并将它们循环成多个 LIKES。做一些替换以抽出 AND、OR 等,然后运行爆炸。

然后循环。

$sql = SELECT * from Buckets where";

循环数组, $sql .= "bucketname LIKE '%" 。 $arrayEl[i] 。 "% OR'。只需确保在最后一次迭代中不包含最后一个 OR 或附加最后一行 0=1 等。

不优雅,效率不高,但在这种情况下它会起作用。老实说,如果它是一个文本字段,你最好运行全文搜索。

【讨论】:

【参考方案5】:

我想要在 MySQL 数据库中进行多词搜索时使用基本 SQL。所以我想出了以下内容。

$terms=explode(" ",$search);
$count=count($terms);
$sql="SELECT * FROM product WHERE";                     
for($i=0;$i<$count;$i++)

    if($i!=$count-1)
        $sql = $sql.
        " (pname LIKE '%$terms[$i]%' OR category LIKE '%$terms[$i]%' OR    
          sub_category LIKE '%$terms[$i]%' OR 
          description LIKE '%$terms[$i]%') AND ";
    else
        $sql = $sql.
        "(pname LIKE '%$terms[$i]%' OR category LIKE '%$terms[$i]%' OR 
         sub_category LIKE '%$terms[$i]%' OR 
         description LIKE '%$terms[$i]%')";
    

【讨论】:

【参考方案6】:

您可以将“apple and pear”拆分为 2 个字符串; “苹果”和“梨”。也许,那你可以做WHERE bucketname LIKE '%apple%' OR bucketname LIKE '%pear%'。我不知道这是否有帮助。

【讨论】:

以上是关于PHP SQL SELECT where like search item with multiple words的主要内容,如果未能解决你的问题,请参考以下文章

sql select where like 变量模糊查询

PHP

string SQL="select * from where "+searchtype+" like '%"+searchkey+"%

SQL语句中模糊查询中不区分大小写怎么写?如:select × from table where number like‘%PK%’

访问 SQL 查询:WHERE AND LIKE 语句中的 * 通配符有问题

SQL语句中关于select……like的问题