全文索引的使用

百度搜索怎么做到快速检索的呢,是用到了全文索引,以mysql为例,介绍一下全文索

 CREATE TABLE articles (
  id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY ,
  title VARCHAR(200),
  body TEXT,
  FULLTEXT(title,body)

 ) ENGINE = MyIsam CHARSET =utf8;

注意亮点:

1、全文索引的存储引擎一定是myisam,InnoDB没有全文索引

2、mysql的fulltext不支持中文,做分词搜索可以sphinx技术来处理中文

INSERT INTO articles(title,body) VALUES
 ('nihao','hello'),
 ('hei','hello xiaoming'),
 ('mysql','innodb');

假如我们要匹配body内容是hello的数据

select * from articles where body like 'hello%';

这样全文索引建了和没建是一样的,那么我们应该这样写

select * from articles where match(title,body) against('hello') ;

大家可以用explain 来对比一下以上两句sql是否用了索引

explain select * from articles where body like 'hello%' \G; 
explain select * from articles where match(title,body) against('hello') \G;

再给大家介绍一下停止词

在50%以上的记录中都会出现的词,不会被做全文索引,也就是说做全文索引,必须是海量数据


                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值