PHP code example of openregion / sphinxql-query-builder
1. Go to this page and download the library: Download openregion/sphinxql-query-builder library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
openregion / sphinxql-query-builder example snippets
use OpenRegion\SphinxQL\Drivers\Mysqli\Connection;
use OpenRegion\SphinxQL\SphinxQL;
$conn = new Connection();
$conn->setParams([
'host' => '127.0.0.1',
'port' => 9306,
]);
$rows = (new SphinxQL($conn))
->select('id', 'gid', 'title')
->from('rt')
->match('title', 'vacation')
->where('gid', '>', 300)
->orderBy('id', 'DESC')
->limit(5)
->execute()
->getStored();
use OpenRegion\SphinxQL\Drivers\Pdo\Connection;
$conn = new Connection();
$conn->setParams([
'host' => '127.0.0.1',
'port' => 9306,
'charset' => 'utf8',
]);
use OpenRegion\SphinxQL\SphinxQL;
$sql = (new SphinxQL($conn))
->select('a.id')
->from('rt a')
->leftJoin('rt b', 'a.id', '=', 'b.id')
->where('a.id', '>', 1)
->compile()
->getCompiled();
// SELECT a.id FROM rt a LEFT JOIN rt b ON a.id = b.id WHERE a.id > 1
(new SphinxQL($conn))
->insert()
->into('rt')
->columns('id', 'gid', 'title', 'content')
->values(10, 9003, 'modifying the same line again', 'because i am that lazy')
->values(11, 201, 'replacing value by value', 'i have no idea who would use this directly')
->execute();
(new SphinxQL($conn))
->replace()
->into('rt')
->set([
'id' => 10,
'gid' => 9002,
'title' => 'modified',
'content' => 'this field was modified with replace',
])
->execute();
(new SphinxQL($conn))
->update('rt')
->where('id', '=', 15)
->value('tags', [111, 222])
->execute();
$sql = (new SphinxQL($conn))
->select('id')
->from('rt')
->orderByKnn('embeddings', 5, [0.1, 0.2, 0.3])
->compile()
->getCompiled();
// SELECT id FROM rt ORDER BY KNN(embeddings, 5, [0.1,0.2,0.3]) ASC
$subquery = (new SphinxQL($conn))
->select('id')
->from('rt')
->orderBy('id', 'DESC');
$sql = (new SphinxQL($conn))
->select()
->from($subquery)
->orderBy('id', 'ASC')
->compile()
->getCompiled();
// SELECT * FROM (SELECT id FROM rt ORDER BY id DESC) ORDER BY id ASC
use OpenRegion\SphinxQL\Helper;
$helper = new Helper($conn);
$tables = $helper->showTables()->execute()->getStored();
$variables = Helper::pairsToAssoc($helper->showVariables()->execute()->getStored());
$keywords = $helper->callKeywords('test case', 'rt', 1)->execute()->getStored();
use OpenRegion\SphinxQL\Facet;
use OpenRegion\SphinxQL\SphinxQL;
$facet = (new Facet($conn))
->facet(['gid'])
->orderBy('gid', 'ASC');
$batchRows = (new SphinxQL($conn))
->select()
->from('rt')
->facet($facet)
->executeBatch()
->getStored();
// $batchRows[0] is SELECT data
// $batchRows[1] is FACET aggregation data
use OpenRegion\SphinxQL\Helper;
use OpenRegion\SphinxQL\SphinxQL;
$batch = (new SphinxQL($conn))
->select()
->from('rt')
->where('gid', 9003)
->enqueue()
->select()
->from('rt')
->where('gid', 201)
->enqueue((new Helper($conn))->showMeta())
->executeBatch();
$all = $batch->getStored();
use OpenRegion\SphinxQL\Percolate;
(new Percolate($conn))
->insert('@subject orange')
->into('pq')
->tags(['tag2', 'tag3'])
->filter('price>3')
->execute();
$matches = (new Percolate($conn))
->callPQ()
->from('pq')
->documents(['{"subject":"document about orange"}'])
->options([
Percolate::OPTION_QUERY => 1,
Percolate::OPTION_DOCS => 1,
])
->execute()
->fetchAllAssoc();
use OpenRegion\SphinxQL\Helper;
$helper = new Helper($conn);
$caps = $helper->getCapabilities();
if ($helper->supports('call_autocomplete')) {
$rows = $helper->callAutocomplete('te', 'rt', ['fuzzy' => 1])->execute()->getStored();
}
Loading please wait ...
Before you can download the PHP files, the dependencies should be resolved. This can take some minutes. Please be patient.