2

我在搜索查询时遇到问题。

我有两列名为'artist'& 'title'。但是对于自动完成功能,我需要一个 SQL 查询来在有人键入时在这些列中进行搜索。我知道有一个非常简单的解决方案,如下所示:

SELECT * FROM music WHERE artist LIKE '%".$term."%' OR title LIKE
'%".$term."%'

$term = 文本框值

但是这个查询有几个大问题。假设艺术家是'DJ Test',标题是'Amazing Test Song'。如果我输入'DJ'它工作正常。但是当我输入'DJ Amazing'. 没有找到搜索结果。显然当然,但我不知道如何解决它。

但这不是唯一的问题。如果有人输入'DJ Test - Amazing Test Song'它必须忽略'-'。

所以我的问题是,当我可以输入“Amazing DJ Test”之类的内容并仍然返回我需要的内容时,我的搜索查询会是什么样子?

4

2 回答 2

0

您必须将搜索字符串拆分为单词,然后通过将这些单词附加到查询中来将它们添加为查找条件。

首先创建一个数组,其中包含搜索字符串中的每个单词。

$search  = 'DJ TEST Amazing Test Song';
$search_terms = explode(" ", $search);

然后更改每个搜索词的查询:

foreach($search_terms as $search_term) {
     //append OR to query with $search_term
     $query .= "OR artist LIKE '%".$search_term."%' OR title LIKE '%".$search_term."%'";

}
于 2013-10-29T20:25:29.237 回答
0

尝试这样的事情。

我认为它应该可以工作,但我还没有测试过。

    $terms = explode(' ', $term);

    foreach($terms as $term){

        $query  = SELECT * FROM music WHERE artist LIKE '%".$term."%' OR title LIKE '%".$term."%'

        return $query;

    }

应该有希望工作

于 2013-10-29T20:20:31.367 回答