IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> php操作elasticsearch -> 正文阅读

[大数据]php操作elasticsearch

首先在composer.json 加上以下代码。

 "elasticsearch/elasticsearch": "~6.0"

使用composer 完成拓展的加载

composer update elasticsearch/elasticsearch

添加索引

public function createIndex()
    {
        $client = ClientBuilder::create()->build();
        $params = [
            'index' => 'new_home',
            //索引名
            'body' => [
                'settings' => [
                    //分片
                    'number_of_shards' => 3,
                    'number_of_replicas' => 2
                ],
                'mappings' => [
                    '_source' => [
                        'enabled' => true
                    ],
                    'properties' => [
                        //字段名称
                        'name' => [
                            //文字
                            'type' => 'text',
                            //ik分词器
                            "analyzer" => "ik_max_word",
                            "search_analyzer" => "ik_max_word"
                        ],
                        'id' => [
                            //数值
                            'type' => 'integer'
                        ]
                    ]
                ]
            ]
        ];
        $response = $client->indices()->create($params);
        var_dump($response);
    }
elasticsearch添加数据
 public function addEs($id, $name)
    {
        $client = ClientBuilder::create()->build();
        $params = [
            //索引名
            'index' => 'new_home',
            'type' => '_doc',  
            //指定id
            'id' => $id,
            //内容
            'body' => [
                'name' => $name,
                'id' => $id
            ]
        ];
        $response = $client->index($params);
        print_r($response);
        echo "<br>";
    }

elasticsearch搜索

public function searchEs(Request $request)
    {
        $name = $request['name'];
        if (empty($name)) {
            return showMsg(500, '查询条件不能为空');
        }
        $client = ClientBuilder::create()->build();
        $params = [
            //索引名
            'index' => 'new_home',
            'type' => '_doc',
            'body' => [
                'query' => [
                    'match' => [
                        //条件
                        'name' => $name
                    ]
                ],
                //高亮显示
                'highlight' => [
                    'pre_tags' => ["<font color='red'>"],
                    'post_tags' => ["</font>"],
                    'fields' => [
                        "name" => new \stdClass()
                    ]
                ]
            ]
        ];
        //前台高亮显示
        /**
         * {!! $变量  !!}
         */
        $results = $client->search($params);
        return showMsg(200, '查询成功', $results['hits']['hits']);
    }

以下为全部代码

<?php

namespace App\Http\Controllers;

//composer update  elasticsearch/elasticsearch
use Illuminate\Http\Request;
use Elasticsearch\ClientBuilder;


class newRoomController extends Controller
{
    /**
     * 创建索引
     */
    public function createIndex()
    {
        $client = ClientBuilder::create()->build();
        $params = [
            'index' => 'new_home',
            //索引名
            'body' => [
                'settings' => [
                    //分片
                    'number_of_shards' => 3,
                    'number_of_replicas' => 2
                ],
                'mappings' => [
                    '_source' => [
                        'enabled' => true
                    ],
                    'properties' => [
                        //字段名称
                        'name' => [
                            //文字
                            'type' => 'text',
                            //ik分词器
                            "analyzer" => "ik_max_word",
                            "search_analyzer" => "ik_max_word"
                        ],
                        'id' => [
                            //数值
                            'type' => 'integer'
                        ]
                    ]
                ]
            ]
        ];
        $response = $client->indices()->create($params);
        var_dump($response);
    }

    /**
     * es添加数据
     * @param $id
     * @param $name
     */
    public function addEs($id, $name)
    {
        $client = ClientBuilder::create()->build();
        $params = [
            //索引名
            'index' => 'new_home',
            'type' => '_doc',
            //指定id
            'id' => $id,
            //内容
            'body' => [
                'name' => $name,
                'id' => $id
            ]
        ];
        $response = $client->index($params);
        print_r($response);
        echo "<br>";
    }

    /**
     * mysql同步es
     */
    public function mysql_es()
    {
        $date = \App\Models\newRoom::select('id', 'title')->get();
        foreach ($date as $v) {
            $this->addEs($v['id'], $v['title']);
        }
    }

    /**
     * es搜索
     * @param Request $request
     * @return false|string
     */
    public function searchEs(Request $request)
    {
        $name = $request['name'];
        if (empty($name)) {
            return showMsg(500, '查询条件不能为空');
        }
        $client = ClientBuilder::create()->build();
        $params = [
            //索引名
            'index' => 'new_home',
            'type' => '_doc',
            'body' => [
                'query' => [
                    'match' => [
                        //条件
                        'name' => $name
                    ]
                ],
                //高亮显示
                'highlight' => [
                    'pre_tags' => ["<font color='red'>"],
                    'post_tags' => ["</font>"],
                    'fields' => [
                        "name" => new \stdClass()
                    ]
                ]
            ]
        ];
        //前台高亮显示
        /**
         * {!! $变量  !!}
         */
        $results = $client->search($params);
        return showMsg(200, '查询成功', $results['hits']['hits']);
    }
}

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-02-22 20:40:12  更:2022-02-22 20:42:09 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 10:40:28-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码