好的,所以我试图在多列中进行全文搜索,就像这样简单:
SELECT * FROM pages WHERE MATCH(head, body) AGAINST('some words' IN BOOLEAN MODE)
现在,我想按相关性排序(找到了多少个单词?),我已经可以使用以下方式进行处理:
SELECT * , MATCH (head, body) AGAINST ('some words' IN BOOLEAN MODE) AS relevance
FROM pages
WHERE MATCH (head, body) AGAINST ('some words' IN BOOLEAN MODE)
ORDER BY relevance
现在这是我迷路的部分,我想优先考虑此head
栏中的相关性。
我想我可以创建两个相关性列,一个用于head
,一个用于body
,但是到那时,我将在表中进行三遍相同的搜索,而对于我要创建的函数,性能非常重要,因为查询将被联接并与其他表匹配。
因此,我的主要问题是,有没有一种更快的方法来搜索相关性并确定某些列的优先级?(作为奖励,甚至可能使相关性计数单词在列中出现的次数?)
任何建议或意见将是巨大的。
注意:我将在LAMP服务器上运行它。(WAMP在本地测试中)