sexlog / elasticsearch-query-builder
2.0.0
2024-08-07 18:01 UTC
Requires
- elasticsearch/elasticsearch: v8.14.0
- monolog/monolog: 2.9.2
Requires (Dev)
- phpunit/phpunit: 9.*
- dev-master
- 2.0.0
- 1.4.0
- 1.3.2
- 1.3.1
- 1.3.0
- 1.2.2
- 1.2.1
- 1.2.0
- 1.1.7
- 1.1.6
- 1.1.5
- 1.1.4
- 1.1.3
- 1.1.2
- 1.1.1
- 1.1.0
- 1.0.0
- dev-elastic-upgrade
- dev-poc-att
- dev-fix-null-fields
- dev-test
- dev-fix-prepare-fields
- dev-fix-php83
- dev-php83-support
- dev-fix-404-exception
- dev-add-getById-function
- dev-change-elasticsearch-version
- dev-definition-column-geo-distance
This package is not auto-updated.
Last update: 2024-09-18 18:42:27 UTC
README
这是一个查询ElasticSearch数据的库。我刚刚开始这个库的开发,还有很多工作要做。
我的目标是完全面向对象地与ElasticSearch通信。
示例
基本查询
$hosts = ['10.0.0.10:9200']; $index = 'products'; $client = \Elasticsearch\ClientBuilder::fromConfig(['hosts' => $hosts]); $elasticSearch = new ElasticSearch\ElasticSearch($index, $client); // SELECT * FROM products WHERE product_name = 'ElasticSearch' LIMIT 4 $query = new ElasticSearch\Query(); $query->where('product_name', 'ElasticSearch'); $elasticSearch->setQuery($query) ->take(4) ->get(); // Paging results $results = $elasticSearch->page(1) ->get(); $results = $elasticSearch->page(2) ->get();
带有过滤器的查询
/* * SELECT id, product_name, price, updated_at * FROM products * WHERE product_name LIKE 'car%' AND category = 3 LIMIT 20 OFFSET 0 */ $query = new ElasticSearch\Query(); $query->wildcard('product_name', 'car*'); $filter = new ElasticSearch\Filter(); $filter->where('category', 3); // You should always use the take method before paging $elasticSearch->select('id, product_name, price, updated_at') ->setQuery($query) ->setFilter($filter) ->take(20) ->page(0) ->get(); // Paging $results = $elasticSearch->page(1) ->get();
日志记录
$hosts = ['10.0.0.10:9200']; $index = 'products'; $client = \Elasticsearch\ClientBuilder::fromConfig(['hosts' => $hosts]); $elasticSearch = new ElasticSearch\ElasticSearch($index, $client); $errorHandler = new \Monolog\Handler\StreamHandler('elastic.log', \Monolog\Logger::ERROR); $logger = new \Monolog\Logger('elastic'); $logger->pushHandler($errorHandler); $elasticSearch->setLogger($logger);