multi_query 无法在 mysqli 中通过 sphinxql 更新实时 sphinx 索引

multi_query not working in mysqli to update realtime sphinx index via sphinxql

我们正在使用 Sphinx 实时索引并通过 PHP 的 mysqli 驱动程序与它们通信。单个查询工作正常,但我们正在尝试使用 multi_query.

实现批量更新过程

查询如下所示:

UPDATE rt SET rank = 1 WHERE id = 881523;
UPDATE rt SET rank = 2 WHERE id = 881727;
UPDATE rt ...

(这是在用分号内爆之后,为便于阅读添加了换行符)

我们得到的错误是:

sphinxql: syntax error, unexpected ';', expecting $end near ';UPDATE rt SET rank = 2 WHERE id = 881727'

如果我copy/paste查询进入mysql CLI客户端,没问题:

mysql> UPDATE rt SET rank = 1 WHERE id = 881523;UPDATE rt SET rank = 2 WHERE id = 882884;UPDATE rt SET rank = 3 WHERE id = 881727;
Query OK, 1 row affected (0.01 sec)

Query OK, 1 row affected (0.01 sec)

Query OK, 1 row affected (0.01 sec)

这是 PHP 代码。 $conn 是来自 http://foolcode.github.io/SphinxQL-Query-Builder/ 的连接 class 的一个实例,但我们正在使用 $conn->getConnection():[=20 直接处理基础 mysqli 连接=]

$query = implode(';', $queries);
if($conn->getConnection()->multi_query($query)) {
        do { }
        while($conn->getConnection()->next_result());
}
if($conn->getConnection()->error) {
        error_log("query: " . $query);
        error_log($conn->getConnection()->error);
        die();
}

我尝试使用 SphinxQL 查询生成器连接 class 中的 multiQuery() 函数,结果相同。

声称分号是意外的错误消息对我来说似乎是最奇怪的部分。如果它想要 $end,是否意味着它不支持多个查询?如果它愿意通过 mysql 客户端进行相同的查询,为什么不呢?

$php -v
PHP 5.5.20 (cli) (built: Dec 29 2014 18:02:29) 
Copyright (c) 1997-2014 The PHP Group
Zend Engine v2.5.0, Copyright (c) 1998-2014 Zend Technologies
    with Zend OPcache v7.0.4-dev, Copyright (c) 1999-2014, by Zend Technologies

您收到的错误消息来自 searchd 服务器,因为它 期望与 ;

连接的多个命令

查询在 CLI 中有效,因为 mysql 客户端 本身将其拆分为单独的查询并将它们一个接一个地发送到服务器(请参阅分隔符选项)。 https://mariadb.com/kb/en/mariadb/documentation/clients-and-utilities/mysql-client/delimiters-in-the-mysql-client/

mysqli,有类似的查询功能 http://php.net/manual/en/mysqli.multi-query.php 这是硬编码使用;显然。事实证明,狮身人面像不支持更新查询,仅支持查询 - 请参阅对主要问题的评论。

因此此时(版本 2.2.7),文档 (http://sphinxsearch.com/docs/current/sphinxql-multi-queries.html) 表明多查询支持仅适用于 SELECT、SHOW WARNINGS、SHOW STATUS 和 SHOW META 查询。这解释了为什么 sphinx 期望查询结束而不是 ';'用于更新查询。

Barry 在 sphinx 论坛 (http://sphinxsearch.com/forum/view.html?id=13201) to use the sphinx API's UpdateAttributes (http://sphinxsearch.com/docs/current.html#api-func-updateatttributes) 上向我建议处理批量更新的功能。这非常有效。我们在 EC2 硬件(r3.xlarge,临时 SSD 上的索引)的单个线程上看到两个不同索引(相同数据以两种不同方式索引)的 5k updates/second。