V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
yangyaofei
V2EX  ›  程序员

请教 sphinx 优化的问题

  •  
  •   yangyaofei ·
    yangyaofei · 2016-07-09 18:47:19 +08:00 · 1585 次点击
    这是一个创建于 3059 天前的主题,其中的信息可能已经有所发展或是发生改变。

    用的 sphinx,这个查询勇士能到 40s... 我想问的是,我写 limit=20 还是 limit=100 最终用时都是一样的,如果是 sql 的 limit 的话,一共 100 个结果如果 limit 1 的话应该会快 100 倍吧...所以在 sphinx 里面怎么让每次查询的结果像 mysql 里面一样只是扫描到指定个数就返回呢?感觉 sphinx 里面是找到所有然后再返回的....

    下面是用的语句:有 24w 条数据,基本所有字段都是长文本

    QUERY = '(
        (
        @(ipc_classnum,main_classnum)
            ("H02H9/"|"H02H7/"|"H02H3/"|"H01C7/10"|"H01C7/11"|"H01C7/12"|"H01C8/04"|"H01R"|"H01T")
            
        &@(title,abstractcontent)
         	("Surge"|"overvoltage"|"over-voltage"|"voltage Protect"|"voltage suppress"|"voltage absorb"|"voltage arrest"|"voltage limit")
            
       |@(ipc_classnum,main_classnum)
        	("H02H9/04"|"H02H9/06"))
            
        &@(apply_people)
            ("PEPPERL")
            
        );
        index=project_cus;
        mode=extended2;
        limit=10;
        maxmatches=1500000'
    
    2 条回复    2016-07-10 11:39:02 +08:00
    lyc1116
        1
    lyc1116  
       2016-07-10 10:22:26 +08:00
    40s ,有点夸张了, solr 实现查询很快的
    yangyaofei
        2
    yangyaofei  
    OP
       2016-07-10 11:39:02 +08:00 via Android
    @lyc1116 但是确实 40s ………如果将(title,abstractcontent)部分去掉就 10s 以内了
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2699 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 21ms · UTC 11:58 · PVG 19:58 · LAX 03:58 · JFK 06:58
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.