Sphinx返回空结果

时间:2018-05-22 04:38:50

标签: php pdo sphinx

我有一个Sphinx搜索引擎项目。

问题在于,对于直接搜索(当用户输入他的查询并按下回车键时),它的效果非常好,但是当我尝试实现自动完成时,它会返回零结果。

Sphinx版本是2.0.8(由于某些原因我无法更新)。

我使用此代码进行自动编译(取自here

<?php
$ln_sph = new PDO("mysql:host=127.0.0.1;port={$confs['port2']}",
            '',
            '',
            array
            (
                PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8"  
            )
        );

$stmt = $ln_sph->prepare("SELECT * FROM ".implode(",", $used_indexes)." WHERE MATCH(':match') LIMIT 0,10 OPTION ranker=sph04");

$aq = explode(' ', $query);
if(mb_strlen($aq[count($aq) - 1]) < 3)
{
    $query = $query;
}
else
{
    $query = $query.'*';
}

$stmt->bindValue(':match', $query, PDO::PARAM_STR);         
$stmt->execute();
$products_ids = array();
foreach($stmt->fetchAll() as $data)
{
    //Reading data from sphinx              
}

如果我通过mysql直接从服务器连接到Sphinx

mysql -P10006 --protocol=tcp

并执行相同的查询,例如:

SELECT * FROM `app_catalog_prod_suggests` WHERE MATCH('пирс*') LIMIT 0, 10 OPTION ranker=sph04;

它也可以。

来自sphinx.conf

的索引
index app_catalog_prod_suggests {
    source=app_catalog_prod_suggests
    path=/path/to/index
    enable_star=1
    min_word_len=3
    min_prefix_len=3
    morphology=stem_ru,stem_en,soundex
    charset_type=utf-8
    html_strip=1
}

我做错了什么?

P.S。如果需要,我可以提供额外的数据

UPD。搜索部分

searchd {
        listen=127.0.0.1:10005
        listen=127.0.0.1:10006:mysql41
        log=/path/to/log
        query_log=/path/to/querylog
        binlog_path = #
        pid_file=/path/to/pid
}

2 个答案:

答案 0 :(得分:0)

经过一番尝试后,我发现了这种行为的原因。它不是在Sphinx中,而是在PDO中。

首先,我测试了查询是否正常工作,例如具有一些常量值 - пирс*。我非常惊讶,斯芬克斯完全按照我的需要归还了我。

所以,问题不在于Sphinx。但那时呢?只有一行可以导致它 - $stmt->bindValue(':match', $query, PDO::PARAM_STR);

我已将bindValue替换为bindParam,并开始处理任何查询。

我不知道这种行为的真正原因,如果有人可以解释它会很棒

<强> UPD

经过一些额外测试后,错误不在bindParambindValue中,而是在参数名称中

答案 1 :(得分:0)

我认为你必须使用该代码

$indexes = 'simplecomplete';
$query = trim($_GET['term']);

$stmt = $ln_sph->prepare("SELECT * FROM $indexes WHERE MATCH(:match)  LIMIT $start,$offset OPTION ranker=sph04,field_weights=(title=100,content=1)");
$stmt->bindValue(':match', $query,PDO::PARAM_STR);
    $stmt->execute();
$rows = $stmt->fetchAll();
   $meta = $ln_sph->query("SHOW META")->fetchAll();
foreach($meta as $m) {
    $meta_map[$m['Variable_name']] = $m['Value'];
}

数据库连接

define ( "FREQ_THRESHOLD", 40 );
define ( "SUGGEST_DEBUG", 0);
define ( "LENGTH_THRESHOLD", 2 );
define ( "LEVENSHTEIN_THRESHOLD", 2 );
define ( "TOP_COUNT", 1 );
define ("SPHINX_20",false);
//database PDO
$ln = new PDO( 'mysql:host=127.0.0.1;dbname=test_database;charset=utf8', 'root', '' );

//Sphinx PDO
$ln_sph = new PDO( 'mysql:host=127.0.0.1;port=9306' );