【问题标题】:Optimizing auto-complete FULLTEXT SQL query优化自动完成 FULLTEXT SQL 查询
【发布时间】:2011-09-11 17:25:27
【问题描述】:

我有以下查询用于自动完成搜索框:

  SELECT *, MATCH (screen_name, name) AGAINST ('+query*' IN BOOLEAN MODE) AS SCORE 
  FROM users 
  WHERE MATCH (screen_name, name) AGAINST ('+query*' IN BOOLEAN MODE) 
  ORDER BY SCORE DESC LIMIT 3

我在 screen_name 和 name(一起)上也有一个 FULL TEXT 索引。当这张桌子相对较小(50k)时,效果很好。现在该表约为 200k,完成每个查询需要几秒钟(!)。我正在使用 MySql MyISAM。这合理吗?我可以检查哪些方向来改进它,因为它肯定不能满足自动完成查询的需求。

【问题讨论】:

  • 有多少行匹配 WHERE 子句?
  • 您可能需要更改为第三方文本索引,例如 Sphinxsearch.com
  • @Karolis 它取决于查询。如果它只是一两个字母比很多。结果较少的查询应该更容易计算吗?

标签: php mysql database full-text-search query-optimization


【解决方案1】:

MYSQL 匹配真的很慢,你应该看看像Sphinx Search Server 这样的替代方案。

【讨论】:

    猜你喜欢
    • 2023-03-06
    • 1970-01-01
    • 2013-02-27
    • 2015-11-08
    • 1970-01-01
    • 1970-01-01
    • 2018-09-05
    • 2013-01-10
    • 2014-02-04
    相关资源
    最近更新 更多