1

谁能帮我得到我想要的代码?
我有一个输入字段,其中将写入多个关键字。
例子:

opel corsa car

我的数据库中有标签条目,用逗号分隔:

1. opel, corsa
2. car, opel
3. juice
4. car

我想要做的是,实现全文搜索,但基于关键字到关键字搜索,这意味着我想列出包含任何关键字的所有结果。但是,我想将这些搜索词修剪 2 个字母,以防有人搜索 corsoa 或 corsae 而不是 corsa。

到目前为止我得到的是:

$input = $_GET["tag"];
$input = mb_strtolower($input,'UTF-8');
$tag = explode(" ", $input);
$tagCheck = '(tags LIKE "%'.implode('%") OR (tags LIKE "%', $tag).'%")';

并在查询

$dbq = $dbco->prepare("SELECT name FROM table WHERE ".$tagCheck." HAVING MAX(price) < 50000");
4

1 回答 1

0

我建议您更改您的数据库设计(如果可以的话)。

尝试创建一个关系数据库以提高性能,同时使查询“更简单”。

在您的查询中尝试使用 MySQL 的函数 find_in_set。

SELECT ... WHERE FIND_IN_SET('1', field)

例子:

mysql> select * from fruits;
+-------------------------------+
| fruit                         |
+-------------------------------+
| banana, apple, orange, grapes |
+-------------------------------+
1 row in set (0.00 sec)

mysql> select * from fruits where find_in_set(' apple',fruit);
+-------------------------------+
| fruit                         |
+-------------------------------+
| banana, apple, orange, grapes |
+-------------------------------+
1 row in set (0.00 sec)

编辑:

如果您的表是 MyISAM 或 Innodb(使用 MySQL V.5.6.+),您可以创建文本索引并使用 like 进行查询

在你的选择中,使用这个

 SELECT ... WHERE tads like ('%text%')

使用 %(通配符)

于 2012-06-29T13:37:01.483 回答