我刚安装在我的服务器上SphinxQL供应商(我刚接触过这个)我遇到了问题 - 我找不到通过随机选择使脚本正常工作的方法。
这是我的代码:
require "./classes/vendor/autoload.php";
use Foolz\SphinxQL\SphinxQL;
use Foolz\SphinxQL\Connection;
// create a SphinxQL Connection object to use with SphinxQL
$conn = new Connection();
$conn->setParams(array('host' => '127.0.0.1', 'port' => 9306));
$query = SphinxQL::create($conn)->select('*')
->from('documents_titles')
->match('title','welcome')
->orderBy('title', $direction = 'RAND()');
$result = $query->execute();
var_dump($result);
我尝试了许多方法让它随机但没有运气。希望有人能帮助我。
答案 0 :(得分:0)
SphinxQL仅支持asc
和desc
选项,而不支持rand
方向。有关详细信息,请参阅https://github.com/FoolCode/SphinxQL-Query-Builder#group-within-group-order-offset-limit-option。
但是,您可以在PHP中执行此操作:
require "./classes/vendor/autoload.php";
use Foolz\SphinxQL\SphinxQL;
use Foolz\SphinxQL\Connection;
// create a SphinxQL Connection object to use with SphinxQL
$conn = new Connection();
$conn->setParams(array('host' => '127.0.0.1', 'port' => 9306));
$query = SphinxQL::create($conn)->select('*')
->from('documents_titles')
->match('title','welcome');
$result = $query->execute();
shuffle($result); // <-- ADD THIS LINE
var_dump($result);