MySql Fulltext Search not correct with short words

前端 未结 2 1542
轮回少年
轮回少年 2021-01-26 01:51

After many tries and many searches i came to the following query:

SELECT id,
       title,
       description,
       MATCH(title,description,tags) AGAINST (\'$s         


        
2条回答
  •  有刺的猬
    2021-01-26 02:13

    1. Question

    This has been discussed on SO quite a few times: MySQL's built-in fulltext parser is designed for searching for words, not for single characters and comes with default minimum word length setting of 3 (innodb) or 4 (myisam) These settings mean that no words shorter than 3 or 4 words get indexed and therefore will not be found by a fulltext search. You may lower the minimum character length limit to 1 and rebuild the index, but it will slow the searching down, since the indexes will be bigger.

    1. Question

    It is possible, but you need to search on the title field separately and bump up the relevancy score results from the title field.

    You can use union to get a combined list with sum() to sum the score up for any record:

    SELECT p.id, any_value(title), any_value(description), any_value(tags), sum(t.score) as sum_score
    FROM
        (SELECT id, (MATCH(title) AGAINST ('$search' IN NATURAL LANGUAGE MODE)) *2 AS score
         FROM pages
         UNION ALL
         SELECT id, MATCH(description,tags) AGAINST ('$search' IN NATURAL LANGUAGE MODE) AS score
         FROM pages) t
    INNER JOIN pages p on t.id=p.id
    GROUP BY p.id
    ORDER BY sum(t.score) DESC
    

    You need to adjust the fulltext indexes to be able to do the separate searches.

提交回复
热议问题