ElasticSearch索引庫、文檔、RestClient操作

文章目錄

  • 一、索引庫
    • 1、mapping屬性
    • 2、索引庫的crud
  • 二、文檔的crud
  • 三、RestClient

一、索引庫

es中的索引是指相同類型的文檔集合,即mysql中表的概念
映射:索引中文檔字段的約束,比如名稱、類型

1、mapping屬性

mapping映射是對索引庫中文檔的約束。類似mysql對表單字段的約束

{"id":[1, 2, 3, 4, 5],"name":{"firstname":"明","lastname":"李"}
}
  • type:字段數據類型,常見的類型有:
    • 字符串:text(可分詞的文本)、keyword(不可分詞的文本,例如國家、品牌、IP地址)
    • 布爾:boolean
    • 日期:date
    • 數值:long、short、byte、integer、double、float
    • Object:對象
      es里面沒有數組類型,json格式key、value,允許value有多個值。上圖id字段
  • index:是否創建索引,默認為true。就是是否創建倒排索引,不創建之后就不能通過它搜索。
  • analyzer:使用那種分詞器
  • properties:該字段的子字段,上面name

2、索引庫的crud

# 建立索引庫
PUT /linsy
{"mappings": {"properties": {"info": {"type": "text","analyzer": "ik_smart"},"email": {"type": "keyword","index": false},"name": {"type": "object","properties": {"firstname": {"type": "keyword"},"lastName": {"type": "keyword"}}}}}
}

查詢索引庫 GET /索引庫名 GET /linsy
刪除索引庫 DELETE /索引庫名

ES 禁止修改索引庫字段類型及屬性,會影響整個索引的結構,但是允許在原有索引庫中新增字段。
注意不能新增已有字段

PUT /索引庫名/_mapping
{"properties": {"新字段名": {"type": "新字段類型"}}
}

二、文檔的crud

新增操作

POST /索引庫名/_doc/文檔id
{"字段1": "值1,"字段2": "值2","字段3": "值3",
}

查詢 GET /索引庫名/_doc/文檔id
刪除 DELETE /索引庫名/_doc/文檔id

# 文檔操作
# 插入
POST /linsy/_doc/1
{"age": "11","email": "linsy@linsy.work","info": "this is a first test 文檔","name": {"firstname": "明","lastName": "李"}
}GET  /linsy/_doc/1DELETE /linsy/_doc/1POST /linsy/_update/1
{"doc":{"age":1111}
}

修改文檔:

  • 全量修改:刪除舊文檔,添加新文檔。就是將上面新增的 DSL 改為 PUT
PUT /索引庫名/_doc/文檔id
{"字段1": "值1,"字段2": "值2","字段3": "值3",
}
  • 增量修改,修改指定字段
POST /索引庫名/_update/文檔id
{"doc":{"字段名":"新的值"}
}

三、RestClient

springboot 導入elasticsearch依賴需注意,它默認使用的版本和springboot的版本一致,你需要對應到安裝在服務器上的版本。

        <dependency><groupId>org.elasticsearch.client</groupId><artifactId>elasticsearch-rest-high-level-client</artifactId></dependency>
    <properties><java.version>8</java.version><elasticsearch.version>7.17.11</elasticsearch.version></properties>

在這里插入圖片描述

在這里插入圖片描述
在這里插入圖片描述
創建索引庫的mapping映射

PUT /hotel
{"mappings": {"properties": {"id":{"type": "keyword"},"name":{"type": "text","analyzer": "ik_max_word","copy_to": "all"},"address":{"type": "keyword","index": false},"price":{"type": "integer"},"score":{"type": "integer"},"brand":{"type": "keyword","copy_to": "all"},"city":{"type": "keyword"},"starName":{"type": "keyword"},"business":{"type": "keyword","copy_to": "all"},"location":{"type": "geo_point"},"pic":{"type": "keyword","index": false},"all":{"type": "text","analyzer": "ik_max_word"}}}
}

RestHighLevelClient 的使用
在這里插入圖片描述

        RestHighLevelClient restHighLevelClient = new RestHighLevelClient(RestClient.builder(HttpHost.create("http://http://192.168.52.150:9200")));// index的增刪查CreateIndexRequest createIndexRequest = new CreateIndexRequest("linsy");createIndexRequest.source("建立索引庫語句(put)", XContentType.JSON);restHighLevelClient.indices().create(createIndexRequest, RequestOptions.DEFAULT);restHighLevelClient.indices().delete(new DeleteIndexRequest("要刪除的索引庫名"), RequestOptions.DEFAULT);// 判斷是否存在boolean b = restHighLevelClient.indices().exists(new GetIndexRequest("索引庫名"), RequestOptions.DEFAULT);

es8.x已經棄用了RestHighLevelClient
官方創建RestClient文檔

文檔的crud
在這里插入圖片描述
查詢文檔
在這里插入圖片描述

在這里插入圖片描述

    @Autowiredprivate IHotelService iHotelService;@BeforeEachpublic void before() {restHighLevelClient = new RestHighLevelClient(RestClient.builder(HttpHost.create("http://192.168.52.150:9200")));}@AfterEachpublic void after() throws IOException {restHighLevelClient.close();}@Testpublic void addDocumentTest() throws IOException {Hotel hotel = iHotelService.getById(61075);HotelDoc hotelDoc = new HotelDoc(hotel);IndexRequest indexRequest = new IndexRequest("hotel").id(hotel.getId().toString());indexRequest.source(JSON.toJSONString(hotelDoc), XContentType.JSON);restHighLevelClient.index(indexRequest, RequestOptions.DEFAULT);}@Testpublic void queryDocumentTest() throws IOException {GetResponse getResponse = restHighLevelClient.get(new GetRequest("hotel", "61075"), RequestOptions.DEFAULT);String json = getResponse.getSourceAsString();System.out.println(json);}@Testpublic void updateDocumentTest() throws IOException {UpdateRequest updateRequest = new UpdateRequest("hotel", "61075");updateRequest.doc("city", "北京","score", "90");restHighLevelClient.update(updateRequest, RequestOptions.DEFAULT);}@Testpublic void deleteDocumentTest() throws IOException {restHighLevelClient.delete(new DeleteRequest("hotel", "61075"), RequestOptions.DEFAULT);}@Testpublic void batchAdd() throws IOException {BulkRequest bulkRequest = new BulkRequest();List<Hotel> list = iHotelService.list();for (Hotel hotel : list) {HotelDoc hotelDoc = new HotelDoc(hotel);bulkRequest.add(new IndexRequest("hotel").id(hotel.getId().toString()).source(JSON.toJSONString(hotelDoc), XContentType.JSON));}restHighLevelClient.bulk(bulkRequest, RequestOptions.DEFAULT);}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/43536.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/43536.shtml
英文地址,請注明出處:http://en.pswp.cn/news/43536.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Elasticsearch在部署時,對Linux的設置有哪些優化方法?

部署Elasticsearch時&#xff0c;可以通過優化Linux系統的設置來提升性能和穩定性。以下是一些常見的優化方法&#xff1a; 1.文件描述符限制 Elasticsearch需要大量的文件描述符來處理數據和連接&#xff0c;所以確保調整系統的文件描述符限制。可以通過修改 /etc/security/…

Docker-compose搭建Git私服

1. 新建個專用的目錄&#xff0c;然后在里面新建個docker-compose.yml文件&#xff1a; &#xff08;gitlab-ce是社區版&#xff0c;當然還有ee&#xff0c;是商業版&#xff09; version: 3.6 …

es自定義分詞器支持數字字母分詞,中文分詞器jieba支持添加禁用詞和擴展詞典

自定義分析器&#xff0c;分詞器 PUT http://xxx.xxx.xxx.xxx:9200/test_index/ {"settings": {"analysis": {"analyzer": {"char_test_analyzer": {"tokenizer": "char_test_tokenizer","filter": [&…

公網遠程連接Redis數據庫詳解

文章目錄 1. Linux(centos8)安裝redis數據庫2. 配置redis數據庫3. 內網穿透3.1 安裝cpolar內網穿透3.2 創建隧道映射本地端口 4. 配置固定TCP端口地址4.1 保留一個固定tcp地址4.2 配置固定TCP地址4.3 使用固定的tcp地址連接 前言 潔潔的個人主頁 我就問你有沒有發揮&#xff0…

ssh免密登陸報錯ERROR: @ WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!

問題描述&#xff1a; 在日常的運維中需要做ssh的免密登陸有提示如下的報錯內容&#xff1a; [rootpaas-harbor01 cce-v5.2.3]# ssh-copy-id 192.45.66.14 /usr/bin/ssh-copy-id: INFO: Source of key(s) to be installed: "/root/.ssh/id_rsa.pub" /usr/bin/ssh-c…

通訊錄實現【C語言】

目錄 前言 一、整體邏輯分析 二、實現步驟 1、創建菜單和多次操作問題 2、創建通訊錄 3、初始化通訊錄 4、添加聯系人 5、顯示聯系人 6、刪除指定聯系人 ?7、查找指定聯系人 8、修改聯系人信息 9、排序聯系人信息 三、全部源碼 前言 我們上期已經詳細的介紹了自定…

Java SpringBoot Vue ERP系統

系統介紹 該ERP系統基于SpringBoot框架和SaaS模式&#xff0c;支持多租戶&#xff0c;專注進銷存財務生產功能。主要模塊有零售管理、采購管理、銷售管理、倉庫管理、財務管理、報表查詢、系統管理等。支持預付款、收入支出、倉庫調撥、組裝拆卸、訂單等特色功能。擁有商品庫存…

ubuntu設置共享文件夾成功后卻不顯示找不到(已解決)

1.首先輸下面命令查看是否真的設置成功共享文件夾 vmware-hgfsclient如果確實已經設置過共享文件夾將輸出window下共享文件夾名字 2.確認自己已設置共享文件夾后輸入下面的命令 //如果之前沒有命令包則先執行sudo apt-get install open-vm-tools sudo vmhgfs-fuse .host:/ /mn…

十六、Spring Cloud Sleuth 分布式請求鏈路追蹤

目錄 一、概述1、為什么出出現這個技術&#xff1f;需要解決哪些問題2、是什么&#xff1f;3、解決 二、搭建鏈路監控步驟1、下載運行zipkin2、服務提供者3、服務調用者4、測試 一、概述 1、為什么出出現這個技術&#xff1f;需要解決哪些問題 2、是什么&#xff1f; 官網&am…

spss---如何使用信度分析以及案例分析

信度分析 問卷調查法是教育研究中廣泛采用的一種調查方法&#xff0c;根據調查目的設計的調查問卷是問卷調查法獲取信息的工具&#xff0c;其質量高低對調查結果的真實性、適用性等具有決定性的作用。 為了保證問卷具有較高的可靠性和有效性&#xff0c;在形成正式問卷之 前&…

CLion:最好用的c/c++編寫工具(最詳細安裝教程)

目錄 一.前言介紹 1.下載安裝 1.1右上角點擊下載 1.2選擇自己操作系統&#xff0c;然后點擊下載 1.3選擇next 1.4 更改路徑 1.5D盤最好 1.6 按照我的選擇配置環境 1.7install安裝 1.8 安裝完成 2、mingw64安裝 2.1下載資源壓縮包 2.2mingw64放入到合適的位置&#xff0c;…

Redis五大基本數據類型及其使用場景

文章目錄 **一 什么是NoSQL&#xff1f;****二 redis是什么&#xff1f;****三 redis五大基本類型**1 String&#xff08;字符串&#xff09;**應用場景** 2 List&#xff08;列表&#xff09;**應用場景** 3 Set&#xff08;集合&#xff09;4 sorted set&#xff08;有序集合…

高級藝術二維碼制作教程

最近不少關于二維碼制作的&#xff0c;而且都是付費。大概就是一個好看的二維碼&#xff0c;掃描后跳轉網址。本篇文章使用Python來實現&#xff0c;這么簡單花啥錢呢&#xff1f;學會&#xff0c;拿去賣便宜點吧。 文章目錄 高級二維碼制作環境安裝普通二維碼藝術二維碼動態 …

【LVS】2、部署LVS-DR群集

LVS-DR數據包的流向分析 1.客戶端發送請求到負載均衡器&#xff0c;請求的數據報文到達內核空間&#xff1b; 2.負載均衡服務器和正式服務器在同一個網絡中&#xff0c;數據通過二層數據鏈路層來傳輸&#xff1b; 3.內核空間判斷數據包的目標IP是本機VIP&#xff0c;此時IP虛…

批量將Excel中的第二列內容從拼音轉換為漢字

要批量將Excel中的第二列內容從拼音轉換為漢字&#xff0c;您可以使用Python的openpyxl庫來實現。下面是一個示例代碼&#xff0c;演示如何讀取Excel文件并將第二列內容進行拼音轉漢字&#xff1a; from openpyxl import load_workbook from xpinyin import Pinyin # 打開Exce…

Android kotlin系列講解(入門篇)使用Intent在Activity之間穿梭

<<返回總目錄 上一篇:Android kotlin系列講解(入門篇)Activity的理解與基本用法 文章目錄 1、使用顯式Intent2、使用隱式Intent3、更多隱式Intent的用法4、向下一個Activity傳遞數據5、返回數據給上一個Activity1、使用顯式Intent 你應該已經對創建Activity的流程比較…

SASS 學習筆記

SASS 學習筆記 總共會寫兩個練手項目&#xff0c;成品在 https://goldenaarcher.com/scss-study 可以看到&#xff0c;代碼在 https://github.com/GoldenaArcher/scss-study。 什么是 SASS SASS 是 CSS 預處理&#xff0c;它提供了變量&#xff08;雖然現在 CSS 也提供了&am…

C++ 面向對象三大特性——繼承

?<1>主頁&#xff1a;我的代碼愛吃辣 &#x1f4c3;<2>知識講解&#xff1a;C 繼承 ??<3>開發環境&#xff1a;Visual Studio 2022 &#x1f4ac;<4>前言&#xff1a;面向對象三大特性的&#xff0c;封裝&#xff0c;繼承&#xff0c;多態&#xff…

【數倉建設系列之一】什么是數據倉庫?

一、什么是數據倉庫&#xff1f; 數據倉庫(Data Warehouse&#xff0c;簡稱DW)簡單來講&#xff0c;它是一個存儲和管理大量結構化和非結構化數據的存儲集合&#xff0c;它以主題為向導&#xff0c;通過整合來自不同數據源下的數據(比如各業務數據&#xff0c;日志文件數據等)…

內網穿透和服務器+IP 實現公網訪問內網的區別

內網穿透和服務器IP 實現公網訪問內網的區別在于實現方式和使用場景。 內網穿透&#xff08;Port Forwarding&#xff09;&#xff1a;內網穿透是一種通過網絡技術將公網用戶的請求通過中轉服務器傳輸到內網設備的方法。通過在路由器或防火墻上進行配置&#xff0c;將公網請求…