因为要做一个对数据库进行简单匹配查询的搜索框,所以对 MySql 进行关键字匹配查询作了一些了解。
书上给出的匹配查询一般是这两种。
(1)精确匹配,使用等号(=).
例如:select * from table where item = ‘$value”;
(2)模糊匹配,使用 like ‘%$value%’。
例如:select * from table where item like ‘%$value%’;
在一般情况下,这两种查询就能完成任务了,甚至在使用多个关键字的时候也可以变通地使用 like ‘%$value_A%’ or like ‘%$value_B%’… 这样的组合语句完成,但如果数据库较大,
内容较多的时候就不得不考虑使用全文搜索了,因为使用 like 进行模糊匹配效率十分低下。
而MySQL对“全文搜索(又称:全文索引)”字段做了索引来优化搜索,同时MySQL使用自然语言来智能地对结果评级,以去掉不相关的项目。
“全文搜索”在 MySQL 中是一个 FULLTEXT 类型索引。FULLTEXT 索引用于 MyISAM 表。曾尝试在 InnoDB 表中创建FullText 索引出错。
修改表方法:
所以如果表所用的引擎非 MyISAM 可以先备份 MySql, 然后在 PHPMyAdmin 中使用操作菜单来更改表的引擎为 MyISAM。接下来在需要进行“全文搜索”的字段点击“全文搜索”创建。
如果已经确定了表的引擎是 MyISAM,也可直接在命令行模式下使用以下命令:
ALTER TABLE 表名 ADD FULLTEXT INDEX (表字段);
拥有了数据和索引,就可以使用MySQL的全文搜索了,最简单的“全文搜索”是带有MATCH…AGAINST语句的SELECT查询:
SELECT 表字段 FROM 表名 WHERE MATCH (全文搜索表字段) AGAINST (’搜索字符串’);