foolz / sphinxql-query-builder
A PHP query builder for SphinxQL and ManticoreQL with MySQLi and PDO drivers.
v4.0.0
2026-02-28 01:29 UTC
Requires
- php: ^8.2
Requires (Dev)
- phpstan/phpstan: ^1.12
- phpunit/phpunit: ^7 || ^8 || ^9
Replaces
- foolz/sphinxql: v4.0.0
- dev-master
- v4.0.0
- 3.0.3
- 3.0.2
- 3.0.1
- 3.0.0
- 2.1.0
- 2.0.0
- 1.2.0
- 1.1.1
- 1.1.0
- 1.0.4
- 1.0.3
- 1.0.2
- 1.0.1
- 1.0.0
- 0.9.x-dev
- 0.9.9
- 0.9.8
- 0.9.7
- 0.9.6
- 0.9.5
- 0.9.4
- 0.9.3
- 0.9.2
- 0.9.1
- 0.9.0
- 0.8.6
- 0.8.5
- 0.8.4
- 0.8.3
- 0.8.2
- 0.8.1
- 0.8.0
- 0.2.2-alpha
- 0.2.1-alpha
- 0.2.0-alpha
- 0.1.6-alpha
- 0.1.4-alpha
- 0.1.3-alpha
- 0.1.2-alpha
- 0.1.1-alpha
- dev-docs/refurbish-documentation
- dev-docs/refurbish-documentation-v2
- dev-release/4.0.0
- dev-ci/migrate-to-github-actions
- dev-php8
- dev-test/double-single-quote-escape
This package is auto-updated.
Last update: 2026-02-28 02:08:26 UTC
README
A fluent PHP query builder for SphinxQL and ManticoreQL.
It supports:
SELECT,INSERT,REPLACE,UPDATE,DELETEMATCH()building (includingMatchBuilder)FACETqueries- batched/multi-queries
- helper commands (
SHOW,CALL, maintenance operations) - percolate workflows for Manticore
- both
mysqliandPDOdrivers
Installation
composer require foolz/sphinxql-query-builder
Requirements:
- PHP 8.2+
mysqliorpdo_mysql- Running Sphinx Search or Manticore Search server
Quick Start
<?php use Foolz\SphinxQL\Drivers\Mysqli\Connection; use Foolz\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();
Connection Setup
mysqli driver
<?php use Foolz\SphinxQL\Drivers\Mysqli\Connection; $conn = new Connection(); $conn->setParams([ 'host' => '127.0.0.1', 'port' => 9306, 'options' => [ MYSQLI_OPT_CONNECT_TIMEOUT => 2, ], ]);
PDO driver
<?php use Foolz\SphinxQL\Drivers\Pdo\Connection; $conn = new Connection(); $conn->setParams([ 'host' => '127.0.0.1', 'port' => 9306, 'charset' => 'utf8', ]);
Query Builder Examples
Compile SQL before executing
<?php use Foolz\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
Insert rows
<?php (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();
Replace rows
<?php (new SphinxQL($conn)) ->replace() ->into('rt') ->set([ 'id' => 10, 'gid' => 9002, 'title' => 'modified', 'content' => 'this field was modified with replace', ]) ->execute();
Update rows (including MVA)
<?php (new SphinxQL($conn)) ->update('rt') ->where('id', '=', 15) ->value('tags', [111, 222]) ->execute();
Delete rows
<?php $affected = (new SphinxQL($conn)) ->delete() ->from('rt') ->where('id', 'IN', [11, 12, 13]) ->match('content', 'content') ->execute() ->getStored();
Grouped boolean filters
<?php $sql = (new SphinxQL($conn)) ->select() ->from('rt') ->where('gid', 200) ->orWhereOpen() ->where('gid', 304) ->where('id', '>', 12) ->whereClose() ->compile() ->getCompiled(); // SELECT * FROM rt WHERE gid = 200 OR ( gid = 304 AND id > 12 )
MATCH with builder callback
<?php $rows = (new SphinxQL($conn)) ->select() ->from('rt') ->match(function ($m) { $m->field('content') ->match('directly') ->orMatch('lazy'); }) ->execute() ->getStored();
ORDER BY KNN
<?php $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
Subqueries
<?php $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
Helper API Example
<?php use Foolz\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();
Compile examples from tests:
$helper->showTables()->compile()->getCompiled()->SHOW TABLES$helper->showTables('rt')->compile()->getCompiled()->SHOW TABLES LIKE 'rt'$helper->showTableStatus()->compile()->getCompiled()->SHOW TABLE STATUS$helper->showTableStatus('rt')->compile()->getCompiled()->SHOW TABLE rt STATUS$helper->callSuggest('teh', 'rt', ['limit' => 5])->compile()->getCompiled()->CALL SUGGEST('teh', 'rt', 5 AS limit)
FACET Example
<?php use Foolz\SphinxQL\Facet; use Foolz\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
Multi Query / Batch Example
<?php use Foolz\SphinxQL\Helper; use Foolz\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();
Percolate Example (Manticore)
<?php use Foolz\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();
Capability Checks
<?php use Foolz\SphinxQL\Helper; $helper = new Helper($conn); $caps = $helper->getCapabilities(); if ($helper->supports('call_autocomplete')) { $rows = $helper->callAutocomplete('te', 'rt', ['fuzzy' => 1])->execute()->getStored(); }
Result Objects
execute() returns ResultSetInterface:
getStored()fetchAllAssoc()fetchAllNum()fetchAssoc()fetchNum()getAffectedRows()
executeBatch() returns MultiResultSetInterface:
getStored()getNext()
Documentation Map
- Main docs index:
docs/index.rst - Builder guide:
docs/query-builder.rst - Helper guide:
docs/helper.rst - Facets:
docs/features/facet.rst - Multi-query:
docs/features/multi-query-builder.rst - Migration guide:
docs/migrating.rst
Running Tests
./scripts/run-tests-docker.sh
This runs the repository test matrix (mysqli + pdo) in Docker.
Contributing
Pull requests are welcome. Please include tests for behavior changes and keep docs in sync with API updates.