PHP 中运用 elasticsearch

PHP扩展安装

1. 环境要求:PHP_VERSION >= 5.3.9,composer工具


2. 在E盘新建文件夹命名为elastic,,拷贝composer.phar到
     E:/elastic目录下面


3. 打开命令行窗口,进入E:/elastic


4. 在命令行运行:
      php composer.phar require elasticsearch/elasticsearch


5. 此时E:/elastic目录下会出现一个vendor目录,安装成功


6. 使用方法:
       require 'vendor/autoload.php'; 
      $client = new Elasticsearch\Client();



创建索引


   include('./vendor/autoload.php');
   $elastic = new Elasticsearch\Client();
   $index[‘index’] = ‘log’;  //索引名称
   $index[‘type’] = ‘ems_run_log’; //类型名称
   $data[‘body’][‘settings’][‘number_of_shards’] = 5;  //主分片数量
   $data[‘body’][‘settings’][‘number_of_replicas’] = 0; //从分片数量
   $elastic->indices()->create($index);


插入索引数据

 include('./vendor/autoload.php');
   $elastic = new Elasticsearch\Client();
   $index[‘index’] = ‘log’; //索引名称
   $index[‘type’] = ‘ems_run_log’; //类型名称
   $index[‘id’] = 1   //不指定id,系统会自动生成唯一id
   $index[‘body’] = array(
       ‘mac’ => 'fcd5d900beca',
       ‘customer_id’ => 3,
       ‘product_id’ => 5,
       ‘version’ => 2
   );
   $elastic->index($index);


查询

include('./vendor/autoload.php');
   $elastic = new Elasticsearch\Client();
   $index[‘index’] = ‘log’; //索引名称
   $index[‘type’] = ‘ems_run_log’; //类型名称
   $index[‘body’][‘query’][‘match’][‘mac’] = ‘fcd5d900beca’;
   $index[‘size’] = 10;
   $index[‘from’] = 200;
   $elastic->search($index);


  相当于sql语句:
   select*from ems_run_log where mac=‘fcd5d900beca’
   limit 200,10;<strong>
</strong>


 include('./vendor/autoload.php');
   $elastic = new Elasticsearch\Client();
   $index[‘index’] = ‘log’; //索引名称
   $index[‘type’] = ‘ems_run_log’; //类型名称
   $index[‘body’][‘query’][‘bool’][‘must’] = array(
         array(‘match’ => array(‘mac’ => ‘fcd5d900beca’)),
         array(‘match’ => array(‘product_id’ => 20))
        );
   $index[‘size’] = 10;
   $index[‘from’] = 200;
   $elastic->search($index);


  相当于sql语句:
   select*from ems_run_log where mac=‘fcd5d900beca’
   and product_id = 20 limit 200,10;



   include('./vendor/autoload.php');
   $elastic = new Elasticsearch\Client();
   $index[‘index’] = ‘log’; //索引名称
   $index[‘type’] = ‘ems_run_log’; //类型名称
   $index[‘body’][‘query’][‘bool’][‘should’] = array(
         array(‘match’ => array(‘mac’ => ‘fcd5d900beca’)),
         array(‘match’ => array(‘product_id’ => 20))
        );
   $index[‘size’] = 10;
   $index[‘from’] = 200;
   $elastic->search($index);


  相当于sql语句:
   select*from ems_run_log where mac=‘fcd5d900beca’
   or product_id = 20 limit 200,10;


  include('./vendor/autoload.php');
   $elastic = new Elasticsearch\Client();
   $index[‘index’] = ‘log’; //索引名称
   $index[‘type’] = ‘ems_run_log’; //类型名称
   $index[‘body’][‘query’][‘bool’][‘must_not’] = array(
         array(‘match’ => array(‘mac’ => ‘fcd5d900beca’)),
         array(‘match’ => array(‘product_id’ => 20))
        );
   $index[‘size’] = 10;
   $index[‘from’] = 200;
   $elastic->search($index);


  相当于sql语句:
   select*from ems_run_log where mac!=‘fcd5d900beca’
   and product_id != 20 limit 200,10;


include('./vendor/autoload.php');
   $elastic = new Elasticsearch\Client();
   $index[‘index’] = ‘log’; //索引名称
   $index[‘type’] = ‘ems_run_log’; //类型名称
   $index[‘body’][‘query’][‘range’] = array(
       ‘id’ => array(‘gte’ => 20,’lt’ => 30);
     );
   $index[‘size’] = 10;
   $index[‘from’] = 200;
   $elastic->search($index);


  相当于sql语句:
   select*from ems_run_log where id>=20
   and id<30  limit 200,10;



删除文档

<pre name="code" class="php">include('./vendor/autoload.php');
$elastic = new Elasticsearch\Client();
$index['index'] = 'test';  //索引名称
$index['type'] = 'ems_test'; //类型名称
$index['id'] = 2; 
$elastic->delete($index);


 


  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值