mysql - 两个全文索引的字段能否并在一起查询
问题描述
字段:title,article,都是全文索引。
查询关键词:key1,key2,key3。
SELECT * FROM [表名] WHERE MATCH(article) AGAINST(’key1,key2,key3’);针对一个全文检索的字段是可行的
有没有这种:
SELECT * FROM [表名] WHERE MATCH(title,article) AGAINST(’key1,key2,key3’);
即同时在title+abstract中查找key1,key2,key3。但错误提示:Can’t find FULLTEXT index matching the column list
有没有好办法?
问题解答
回答1:alter table aws_articles add fulltext(title,abstract);就ok了,建立联合索引,单独建立是不行的
回答2:MySQL哪个版本哟?全文搜索支持中文了吗?
回答3:如果是英文字段,如@haixia9060 说的,可新建索引后查询
对三个字段新建索引
ALTER TABLE articles ADD FULLTEXT content_title_keywords_ndx (content,title,keywords);
查询
match(content,title,keywords) against (’cats’ in boolean mode)
MySQL默认只能处理英文/数字类型的;
如果是是中文字段,应按流程(Document->Token->Term->Index)维护倒排索引;也有将MySQL字段指定Analyzer自动维护索引,实时同步到Solr中进行全文索引的做法;
相关文章:
1. Docker for Mac 创建的dnsmasq容器连不上/不工作的问题2. 前端 - webpack如何打包script标签引入的代码3. 如何解决Centos下Docker服务启动无响应,且输入docker命令无响应?4. 在bootstrap中怎么让浏览器缩小到一定大小时,里面的元素就不自适应屏幕大小,而是固定的大小。5. docker-machine添加一个已有的docker主机问题6. css3 - 一个关于CSS雪碧图的问题7. node.js - antdesign怎么集合react-redux对input控件进行初始化赋值8. mac里的docker如何命令行开启呢?9. wordpress - nginx 反代 Varnish 走 Https ,WP后台 ‘您没有足够的权限访问该页面。’10. angular.js - 如何在指令里使用ng-click

网公网安备