thinkphp5 +elasticsearch

php7使用elasticsearchphp

1、安裝java

官網下載地址:https://www.elastic.co/downloads/elasticsearchmysql

# 解壓到非root目錄,運行時使用非root帳號且必須安裝java環境sql

yum install javaapache

wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-6.2.3.tar.gzjson

tar zxvf elasticsearch-6.2.3.tar.gzapi

useradd elasticsearchphp7

password elasticsearchapp

chown elasticsearch:elasticsearch elasticsearch-6.2.3composer

cd elasticsearch-6.2.3

nohup ./bin/elasticsearch  &   #設置成常駐進程

 

# php擴展庫引入  composer.json

{  "require": {    // ...    "elasticsearch/elasticsearch": "~6.0"    // ...  } }

 

# 測試數據導入

create table articles(

  id int not null primary key auto_increment,

  title varchar(200) not null comment '標題',

  content text comment '內容'

);

insert into articles(title, content) values ('Laravel 測試1', '個人寶馬多少馬力'),

('個人寶馬發動機多少', '個人保時捷馬力不錯'),

('Laravel 測試3', '個人寶馬發動機多少');

二、api使用

 

<?php
// +----------------------------------------------------------------------
// | ThinkCMF [ WE CAN DO IT MORE SIMPLE ]
// +----------------------------------------------------------------------
// | Copyright (c) 2013-2018 http://www.thinkcmf.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
// +----------------------------------------------------------------------
// | Author: 老貓 <zxxjjforever@163.com>
// +----------------------------------------------------------------------
namespace app\admin\controller;

use cmf\controller\AdminBaseController;
use think\Db;
use Elasticsearch\ClientBuilder;

/* author@zhou
 * 功能:分詞系統
 * return 
 */
class ElasticController extends AdminBaseController
{
    /* author@zhou
     * 功能:生成索引
     * return
     */
    public function index(){
        try {
            $db = new \PDO('mysql:host=127.0.0.1;dbname=thinkcmf5', 'root', 'd1560a683a5e0d82');

            $sql = 'select * from articles';
            $query = $db->prepare($sql);
            $query->execute();
            $lists = $query->fetchAll();
            print_r($lists);
        } catch (Exception $e) {
            echo $e->getMessage();
        }

        $client = ClientBuilder::create()->build();
        foreach ($lists as $row) {
            $params = [
                'body' => [
                    'id' => $row['id'],
                    'title' => $row['title'],
                    'content' => $row['content']
                ],
                'id' => 'article_' . $row['id'],
                'index' => 'articles_index',
                'type' => 'articles_type'
            ];
            $client->index($params);
        }


    }

    /* author@zhou
     * 功能:獲取索引
     * return
     */
    public function getIndex(){
        $client = ClientBuilder::create()->build();
        $params = [
            'index' => 'articles_index',
            'type' => 'articles_type',
            'id' => 'article_1'
        ];
        $res = $client->get($params);
        print_r($res);
    }
    
    
    /* author@zhou
     * 功能:從索引中刪除文檔
     * return 
     */
    public function delIndex(){
        $client = ClientBuilder::create()->build();
        $params = [
            'index' => 'articles_index',
            'type' => 'articles_type',
            'id' => 'article_1'
        ];
        $res = $client->delete($params);
        print_r($res);

    }


    /* author@zhou
      * 功能:設置索引
      * return
      */
    public function createIndex(){
        $client = ClientBuilder::create()->build();
        $params['index'] = 'articles_index';
        $params['body']['settings']['number_of_shards'] = 2;
        $params['body']['settings']['number_of_replicas'] = 0;
        $client->indices()->create($params);

    }


    /* author@zhou
     * 功能:查詢條件
     * return 
     */
    public function search(){

        $client = ClientBuilder::create()->build();
        $params = [
            'index' => 'articles_index',
            'type' => 'articles_type',
        ];

        //多字段匹配
//        $params['body']['query']['multi_match']['query'] = '個人寶馬發動機多少';
//        $params['body']['query']['multi_match']['fields'] = ["title","content"];
//        $params['body']['query']['multi_match']['type'] ="most_fields"; // most_fields 多字段匹配度更高   best_fields  徹底匹配佔比更高
//
//        //單個字段匹配
//        $params['body']['query']['match']['content'] =  '個人寶馬多少馬力';

        //徹底匹配
//        $params['body']['query']['match_phrase']['content'] =  '個人寶馬多少馬力';


        //聯合搜索  must,should,must_not
        $params['body']['query']["bool"]['must']["match"]['content'] = "寶馬";
        $params['body']['query']["bool"]['must_not']["match"]['title'] = "寶馬";

        $res = $client->search($params);
        print_r($res);

    }

}
相關文章
相關標籤/搜索