目錄
1.建立索引($client->indices()->create())
2.取得索引資訊
2.1 取得索引資訊($client->indices()->getSettings())
2.2 取得Mapping訊息
2.3 修改/新增mapping資訊
2.4 刪除索引
3 es的增刪改查
3.1 增加資料
首頁 後端開發 php教程 Elasticsearch-PHP api簡介

Elasticsearch-PHP api簡介

Apr 13, 2018 am 09:13 AM
api php

這篇文章介紹的內容是關於Elasticsearch-PHP api的簡介,現在分享給大家,有需要的朋友可以參考一下

Elasticsearch 是目前流行的大數據處理框架之一,詳細的說明可以自行百度等.
以下文章採用es縮寫作為代表Elasticsearch

es有官方的php api介面,可以採用github下載或composer.


1.建立索引($client->indices()->create())

      $params = [                'index' => 'user_index',  //索引名(相当于mysql的数据库)
                'body' => [                    'mappings' => [                        'normal_type' => [ //类型名(相当于mysql的表)
                            '_all'=>[   //  是否开启所有字段的检索
                                'enabled' => 'false'
                            ],                            'properties' => [ //文档类型设置(相当于mysql的数据类型)
                                'uid' => [                                    'type' => 'integer' // 字段类型为整型
                                ],                                'username' => [                                    'type' => 'keyword' // 字段类型为关键字,如果需要全文检索,则修改为text,注意keyword字段为整体查询,不能作为模糊搜索
                                ],                                'platform' => [                                    'type' => 'keyword'
                                ],                                'mobile' => [                                    'type' => 'integer'
                                ],                                'sex' => [                                    'type' => 'integer'
                                ],                                'source' => [                                    'type' => 'keyword'
                                ],                                'province' => [                                    'type' => 'keyword'
                                ],                                'city' => [                                    'type' => 'keyword'
                                ],                              'tag' =>   [                                'properties'    =>  [                                    'tagName'   =>[                                        'type' => 'text'
                                    ],                                    'tagWeight'   => [                                        'type' => 'integer',
                                    ]
                                ]
                            ],
                            ]
                        ]
                    ]
                ]
            ];
            $data = $client->indices()->create($params);
登入後複製

簡單的索引就建立完畢了,現在我們可以取得下剛建立的索引資訊.

2.取得索引資訊

2.1 取得索引資訊($client->indices()->getSettings())

     $params = [                'index' => 'user_index',                'client' => [                    'ignore' => 404
                ]
            ];
    $res = $client->indices()->getSettings($params);//获取库索引设置信息
登入後複製

傳回的結果如下:

  array (    'user_index' => 
    array (    'settings' => 
    array (      'index' => 
      array (        'creation_date' => '1498116455327',        'number_of_shards' => '5',        'number_of_replicas' => '1',        'uuid' => '8pkONoI7RAuw5HjnFa4UaQ',        'version' => 
        array (          'created' => '5020299',
        ),        'provided_name' => 'user_index',
        ),
      ),
    ),
 )
登入後複製

2.2 取得Mapping訊息

  • 介面:$client->indices()->getMapping

$params = [                'index' => 'user_index',                'client' => [                    'ignore' => 404
                ]
            ];
$res = $client->indices()->getMapping($params);   //获取mapping信息
登入後複製

返回的結果如下:

array (  'user_index' => 
  array (    'mappings' => 
    array (      'normal_type' => 
      array (        '_all' => 
        array (          'enabled' => false,
        ),        'properties' => 
        array (          'city' => 
          array (            'type' => 'keyword',
          ),          'mobile' => 
          array (            'type' => 'integer',
          ),          'platform' => 
          array (            'type' => 'keyword',
          ),          'province' => 
          array (            'type' => 'keyword',
          ),          'sex' => 
          array (            'type' => 'integer',
          ),          'source' => 
          array (            'type' => 'keyword',
          ),          'uid' => 
          array (            'type' => 'integer',
          ),          'username' => 
          array (            'type' => 'keyword',
          ),
        ),
      ),
    ),
  ),
)
登入後複製

這裡取得的相關資訊就是我們剛剛建立的索引es可以動態的修改以及新增相關的資訊.

2.3 修改/新增mapping資訊

  • #注意事項:已經建立好的欄位類型是不能更改的!!

  • 介面:$client->indices()->putMapping() ;

        $params = [            'index' => 'user_index',  //索引名(相当于mysql的数据库)
            'type'  => 'normal_type',            'body'  =>  [                'normal_type' => [                    'properties'    =>[                        'tag'   =>[                            'type'  => 'text'
                        ]
                    ]
                ]
            ]
        ];
$client->indices()->putMapping($params);
登入後複製

2.4 刪除索引

  • 介面:$client->indices()->delete($params);

        $params = [            'index' => 'user_index',  //索引名(相当于mysql的数据库)
        ];
登入後複製

3 es的增刪改查

3.1 增加資料

  • 單一資料插入

  • #介面:$client->index()

$params = [    'index' => 'my_index',    'type' => 'my_type',    'id' => 'my_id', // 不填则es会自动生成唯一的id
    'body' => [ 'testField' => 'abc']
];
$response = $client->index($params);
登入後複製
  • #批次資料插入

  • ##介面:$ client->bulk();

  •                 foreach($userList as $value){
                        $params['body'][] = [                        'index' => [                            '_index' => 'user_index',                            '_type' => 'normal_type',                            '_id'  =>$value['uid']
                            ]
                        ];
                        $params['body'][] = [                        'uid' => $value['uid'],                        'username' => $value['username'],                        'platform' => $value['platform'],                        'mobile' => $value['mobile'],                        'province' => $value['province'],                        'city' => $value['city'],                        'sex' => $value['gender '],                        'source'=>'xxx'
                        ];
                    }
                    $responses = $client->bulk($params);
    登入後複製
  • #ps:當循環插入大量資料時,需要注意php的記憶體超出限制的問題.(還不清楚這個框架哪部分操作之後沒有釋放記憶體)

3.2 搜尋資料

  • 單一資料搜搜,但是需要知道id

  • 介面:$client->get()

  • $params = [    'index' => 'my_index',    'type' => 'my_type',    'id' => 'my_id' // es 自动生成/自己录入的];
    $response = $client->get($params);
    登入後複製
  • 批次搜尋

  • 介面:$client->search()

  • $params = [  
        'index' =>  'my_index',   //['my_index1', 'my_index2'],可以通过这种形式进行跨库查询  
        'type' => 'my_type',//['my_type1', 'my_type2'],  
        'body' => [  
            'query' => [  
                'match' => [  // 搜索条件
                    'age' => '24' ,                'tag.tagName' =>'tag'  // 如果字段存储的是object.
                                           //这里搜索必须要这样才能搜索出结果.
                ]  
            ],  
            'from' => '0',  // 分页
            'size' => '200'  // 每页数量
            'sort' => [  // 排序
                'age' => 'desc'   //对age字段进行降序排序  
            ]  
        ]  
    ];  
    $res = $client->search($params);
    登入後複製
傳回的資料大致如下:

array (size=4)  'took' => int 2
  'timed_out' => boolean false
  '_shards' => 
    array (size=3)      'total' => int 5
      'successful' => int 5
      'failed' => int 0
  'hits' =>  // 搜索到数据
    array (size=3)      'total' => int 2
      'max_score' => float 1
      'hits' => // 具体数据包
        array (size=1)          0 => 
            array (size=5)
              ...
登入後複製

    ##很多時候需要用到類似mysql的and/or 查詢es搜尋也能做到.
  • 這時候我們就要用到es的組合過濾器
  • https: //www.elastic.co/guide/cn/elasticsearch/guide/current/combining-filters.html 官方文件如下
  • ##以下是測試過的一個例子
  • {    "index": "xxx_index", 
        "type": "normal_type", 
        "body": {        "size": 20, 
            "from": 0, 
            "query": {            "bool": {                "must": [
                        {                        "match": {                            "tag.tagName": "xxxx"
                            }
                        }
                    ]
                }
            }, 
            "sort": {            "uid": "desc"
            }
        }
    }
    登入後複製

    3.3 刪除資料

注意:資料刪除的時候有一定的快取更新時間,在沒更新的時候還是能被搜尋出來.
  • 介面:$client->delete();
  • $param = [                'index' => 'my_index',                'type' => 'my_type',                'id'    => 'my_id'
                ];
                $ret = $this->client->delete($param);
    登入後複製

    傳回資料如下:
  • array (size=7)  'found' => boolean true
      '_index' => string 'user_index' (length=10)  '_type' => string 'normal_type' (length=11)  '_id' => string 'AVzh_QnIZvcaH3gE7MvE' (length=20)  '_version' => int 2
      'result' => string 'deleted' (length=7)  '_shards' => 
        array (size=3)      'total' => int 2
          'successful' => int 1
          'failed' => int 0
    登入後複製
3.4 更新資料

介面:$client->update()
  • $params = [  
        'index' => 'my_index',  
        'type' => 'my_type',  
        'id' => '3416a75f4cea9109507cacd8e2f2aefc',  
        'body' => [  
            'doc' => [  // 必须带上这个.表示是文档操作
                'age' => 150  
            ]  
        ]  
    ];  
    $res = $client->update($params);
    登入後複製

    傳回結果
  • array (size=6)  '_index' => string 'user_index' (length=10)  '_type' => string 'normal_type' (length=11)  '_id' => string 'AVzh_QnIZvcaH3gE7Mw5' (length=20)  '_version' => int 2
      'result' => string 'updated' (length=7)  '_shards' => 
        array (size=3)      'total' => int 2
          'successful' => int 1 // 当数据没有发生变化时这里是为0
          'failed' => int 0
    登入後複製
4.不同索引之間進行倒數據

注意:不同索引之間倒資料時,需要注意欄位的型別,型別不一樣會導致導入失敗,這個時候可以使用script進行處理
  • #此介面不能再phpapi中運作,作為記錄存在
  • 介面:POST _reindex
  • POST _reindex
    {  "source": {    "index": "user_profile"
      },  "dest": {    "index": "user_prfile_v1"
      },  "script": {    "inline": " ctx._source.tag=params.new_tags",    "params": {      "new_tags":{        "tagName":null,        "tagWeight":0
          }
        }
      }
    }
    登入後複製
    #作者:湯敏正

    連結:
    https://www.jianshu.com/p/a2837f487de6

    相關推薦:

    php呼叫接口api的方法

    論vue專案api相關程式碼的組織方式


    #

    以上是Elasticsearch-PHP api簡介的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

適用於 Ubuntu 和 Debian 的 PHP 8.4 安裝和升級指南 適用於 Ubuntu 和 Debian 的 PHP 8.4 安裝和升級指南 Dec 24, 2024 pm 04:42 PM

PHP 8.4 帶來了多項新功能、安全性改進和效能改進,同時棄用和刪除了大量功能。 本指南介紹如何在 Ubuntu、Debian 或其衍生版本上安裝 PHP 8.4 或升級到 PHP 8.4

如何設定 Visual Studio Code (VS Code) 進行 PHP 開發 如何設定 Visual Studio Code (VS Code) 進行 PHP 開發 Dec 20, 2024 am 11:31 AM

Visual Studio Code,也稱為 VS Code,是一個免費的原始碼編輯器 - 或整合開發環境 (IDE) - 可用於所有主要作業系統。 VS Code 擁有大量針對多種程式語言的擴展,可以輕鬆編寫

在PHP API中說明JSON Web令牌(JWT)及其用例。 在PHP API中說明JSON Web令牌(JWT)及其用例。 Apr 05, 2025 am 12:04 AM

JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

php程序在字符串中計數元音 php程序在字符串中計數元音 Feb 07, 2025 pm 12:12 PM

字符串是由字符組成的序列,包括字母、數字和符號。本教程將學習如何使用不同的方法在PHP中計算給定字符串中元音的數量。英語中的元音是a、e、i、o、u,它們可以是大寫或小寫。 什麼是元音? 元音是代表特定語音的字母字符。英語中共有五個元音,包括大寫和小寫: a, e, i, o, u 示例 1 輸入:字符串 = "Tutorialspoint" 輸出:6 解釋 字符串 "Tutorialspoint" 中的元音是 u、o、i、a、o、i。總共有 6 個元

您如何在PHP中解析和處理HTML/XML? 您如何在PHP中解析和處理HTML/XML? Feb 07, 2025 am 11:57 AM

本教程演示瞭如何使用PHP有效地處理XML文檔。 XML(可擴展的標記語言)是一種用於人類可讀性和機器解析的多功能文本標記語言。它通常用於數據存儲

解釋PHP中的晚期靜態綁定(靜態::)。 解釋PHP中的晚期靜態綁定(靜態::)。 Apr 03, 2025 am 12:04 AM

靜態綁定(static::)在PHP中實現晚期靜態綁定(LSB),允許在靜態上下文中引用調用類而非定義類。 1)解析過程在運行時進行,2)在繼承關係中向上查找調用類,3)可能帶來性能開銷。

什麼是PHP魔術方法(__ -construct,__destruct,__call,__get,__ set等)並提供用例? 什麼是PHP魔術方法(__ -construct,__destruct,__call,__get,__ set等)並提供用例? Apr 03, 2025 am 12:03 AM

PHP的魔法方法有哪些? PHP的魔法方法包括:1.\_\_construct,用於初始化對象;2.\_\_destruct,用於清理資源;3.\_\_call,處理不存在的方法調用;4.\_\_get,實現動態屬性訪問;5.\_\_set,實現動態屬性設置。這些方法在特定情況下自動調用,提升代碼的靈活性和效率。

PHP和Python:比較兩種流行的編程語言 PHP和Python:比較兩種流行的編程語言 Apr 14, 2025 am 12:13 AM

PHP和Python各有優勢,選擇依據項目需求。 1.PHP適合web開發,尤其快速開發和維護網站。 2.Python適用於數據科學、機器學習和人工智能,語法簡潔,適合初學者。

See all articles