定制 hovjacky/nosql 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

hovjacky/nosql

最新稳定版本:v3.1.0

Composer 安装命令:

composer require hovjacky/nosql

包简介

PHP Client for Elasticsearch (MongoDB and Cassandra are almost finished) - easy and unified queries

README 文档

README

This package creates unified API for some NoSQL databases (at the time only Elasticsearch, MongoDB and Cassandra need to be finished).

Installation

The recommended way is via Composer:

composer require hovjacky/nosql

It requires PHP version 7.0 and higher.

Usage

Connection parameters (host, port, index) have to be passed as an array to the constructor of ElasticsearchClient.

The following methods are supported:

  • insert - array $data
  • bulkInsert - array $data
  • get - int $id
  • update - int $id, array $data
  • delete - int $id
  • deleteAll
  • findBy - array $params - details described below.

All have table as first parameter (in Elasticsearch it is the type name).

####Method findBy Method findBy can be used for search. It supports quite a wide range of parameters (you can find comparison with SQL in parentheses):

  • fields - array of fields user wants to retrieve (SELECT id, name FROM)
  • limit - max. number of results (LIMIT 10)
  • offset - can only be used with limit (LIMIT 10, 10)
  • count - only get number of results
  • orderBy - array of fields to order by, e.g. ['id', 'name'], descendant order is marked by lowercase desc - ['id desc', 'name'] (ORDER BY id DESC, name)
  • groupBy - array of fields to group by, e.g. ['id', 'name'] (GROUP BY id, name)
  • aggregation - an associative array, keys are aggregation functions like max, min, avg, etc. and values are names of fields the aggregations should apply to, e.g. ['min' => ['id', 'age'], 'avg' => ['age']] (SELECT MIN(id), MIN(age), AVG(age) FROM)
  • where - an associative array, keys are conditions with placeholders (?) and values are values. Conditions accept operators =, !=, >, <, >=, <=, LIKE, IS NULL, IS NOT NULL, CROSS FIELDS.
    • LIKE - the value should contain % (the same as in SQL)
    • = - the value can be an array, e.g. ['id = ?' => [1, 3, 7]] (id IN (1, 3, 7))
    • IS NULL, IS NOT NULL - Elasticsearch only
    • CROSS FIELDS - searching string in multiple fields, e.g. name John Smith in fields firstname and surname. Syntax is "firstname,surname CROSS FIELDS ?" => "John Smith"

统计信息

  • 总下载量: 17.51k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2018-02-14