Rumah  >  Artikel  >  pangkalan data  >  关于MySQL的FULLTEXT实现全文检索需要注意的事项

关于MySQL的FULLTEXT实现全文检索需要注意的事项

小云云
小云云asal
2017-12-13 14:38:111765semak imbas

对于英文,MySQL的FULLTEXT属性来实现全文检索是相当方便且高效的,但是在使用过程中需要注意一些事项MySQL的FULLTEXT实现全文检索的注意事项你知道多少吗,其实这个东西小编测试过不支持中文了,不过既然用了还是有一些事项要注意了。

首先对我们对需要进行检索的字段添加FULLTEXT属性(假设已经建表):

alter table table_name add fulltext index(filed_1,filed_2);

接下来查询数据:

 SELECT * FROM table_name WHERE MATCH (filed_1,filed_2) AGAINST ('keyword');

此处涉及到一个很重要的注意事项:

MySQL规定全文搜索中被搜索的单词所在的行数大于等于被搜索的所有行数的一半时候,就将被搜索单词作为Common word,即不被显示。(具体条件需要查阅资料确定)

因此,假设在测试的时候,表中只有一行数据,所以无论怎么执行上述查询语句,返回的结果总是为空。不必惊慌,多加几条没有待查关键词的数据就会有结果啦~

当然,MySQL提供了更加强大的查询结果过滤:

 SELECT * FROM table_name WHERE MATCH (filed_1,filed_2) AGAINST (' keyword_1 -keyword_2' IN BOOLEAN MODE);

这样,就会返回包含keyword_1的数据,而包含keyword_2的数据就会被过滤掉。

相关推荐:

mysql 全文检索中文解决方法及实例代码分享

PHP+MYSQL实现全文检索及全文检索工具

SQL Server全文检索简介_PHP教程

Atas ialah kandungan terperinci 关于MySQL的FULLTEXT实现全文检索需要注意的事项. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn