日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

听某个老师的ElasticSearch记的笔记了

發(fā)布時(shí)間:2023/12/18 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 听某个老师的ElasticSearch记的笔记了 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

1.1ES簡(jiǎn)介

ES是使用java 語(yǔ)言并且基于lucence編寫(xiě)的搜索引擎框架,他提供了分布式的全文搜索功能,提供了一個(gè)統(tǒng)一的基于restful風(fēng)格的web 接口。

lucence:一個(gè)搜索引擎底層

分布式:突出ES的橫向擴(kuò)展能力

全文檢索:將一段詞語(yǔ)進(jìn)行分詞,并將分出的詞語(yǔ)統(tǒng)一的放在一個(gè)分詞庫(kù)中,再搜索時(shí),根據(jù)關(guān)鍵字取分詞庫(kù)中檢索,找到匹配的內(nèi)容(倒排索引)。

restful風(fēng)格的web 接口:只要發(fā)送一個(gè)http請(qǐng)求,并且根據(jù)請(qǐng)求方式的不同,攜帶參數(shù)的不同,執(zhí)行相應(yīng)的功能。

應(yīng)用廣泛:WIKI, github,Gold man

1.2ES的由來(lái)

回憶時(shí)光**許多年前,一個(gè)剛結(jié)婚的名叫 Shay Banon 的失業(yè)開(kāi)發(fā)者,跟著他的妻子去了倫敦,他的妻子在那里學(xué)習(xí)廚師。 在尋找一個(gè)賺錢的工作的時(shí)候,為了給他的妻子做一個(gè)食譜搜索引擎,他開(kāi)始使用 Lucene 的一個(gè)早期版本。直接使用 Lucene 是很難的,因此 Shay 開(kāi)始做一個(gè)抽象層,Java 開(kāi)發(fā)者使用它可以很簡(jiǎn)單的給他們的程序添加搜索功能。 他發(fā)布了他的第一個(gè)開(kāi)源項(xiàng)目 Compass。后來(lái) Shay 獲得了一份工作,主要是高性能,分布式環(huán)境下的內(nèi)存數(shù)據(jù)網(wǎng)格。這個(gè)對(duì)于高性能,實(shí)時(shí),分布式搜索引擎的需求尤為突出, 他決定重寫(xiě) Compass,把它變?yōu)橐粋€(gè)獨(dú)立的服務(wù)并取名 Elasticsearch。第一個(gè)公開(kāi)版本在2010年2月發(fā)布,從此以后,Elasticsearch 已經(jīng)成為了 Github 上最活躍的項(xiàng)目之一,他擁有超過(guò)300名 contributors(目前736名 contributors )。 一家公司已經(jīng)開(kāi)始圍繞 Elasticsearch 提供商業(yè)服務(wù),并開(kāi)發(fā)新的特性,但是,Elasticsearch 將永遠(yuǎn)開(kāi)源并對(duì)所有人可用。據(jù)說(shuō),Shay 的妻子還在等著她的食譜搜索引擎…

1.3ES和solr

1.solr 查詢死數(shù)據(jù),速度比es快。但是數(shù)據(jù)如果是改變的,solr查詢速度會(huì)降低很多,ES的查詢速度沒(méi)有明顯的改變

2.solr搭建集群 依賴ZK,ES本身就支持集群搭建

3.最開(kāi)始solr 的社區(qū)很火爆,針對(duì)國(guó)內(nèi)文檔 少,ES出現(xiàn)后,國(guó)內(nèi)社區(qū)火爆程度 上升,,ES的文檔非常健全

4.ES對(duì)云計(jì)算和大數(shù)據(jù)支持很好

1.4倒排索引

1.將存放的數(shù)據(jù)以一定的方式進(jìn)行分詞,并將分詞的內(nèi)容存放到一個(gè)單獨(dú)的分詞庫(kù)中。

2.當(dāng)用戶取查詢數(shù)據(jù)時(shí),會(huì)將用戶的查詢關(guān)鍵字進(jìn)行分詞,然后去分詞庫(kù)中匹配內(nèi)容,最終得到數(shù)據(jù)的id標(biāo)識(shí)

3.根據(jù)id標(biāo)識(shí)去存放數(shù)據(jù)的位置拉去指定數(shù)據(jù)

2 安裝

2.1 elasticsearch 安裝

http://hub.daocloud.io/ docker 鏡像工廠地址

version: "3.1" services:elasticsearch: image: daocloud.io/library/elasticsearch:6.5.4restart: alwayscontainer_name: elasticsearchports: - 9200:9200- 9300:9300kibana:image: daocloud.io/library/kibana:6.5.4restart: alwayscontainer_name: kibanaports: - 9200:9200environment:- elasticsearch_url=ip:9200depends_on:- elasticseatch

或者本地下載

2.2

https://github.com/medcl/elasticsearch-analysis-ik/archive/v6.8.10.zip

官方給的安裝的辦法 ./bin/elasticsearch-plugin install https://github.com/medcl/elasticsearch-analysis-ik/releases/download/v6.3.0/elasticsearch-analysis-ik-6.3.0.zip

本地自己安裝

https://github.com/medcl/elasticsearch-analysis-ik/archive/v6.8.10.zip 下載好后, 執(zhí)行 mvn clean package 打包(注意pom文件中的es的版本,如果和自己的es的版本不一致,手動(dòng)改下) elasticsearch-analysis-ik-6.8.10\target\releases 中壓縮包的內(nèi)容copy到 elasticsearch-6.8.10\plugins\ik 下

kibana 主要用到 Dev Tools 和 Management

POST _analyze {"analyzer": "ik_max_word","text":"我是中國(guó)人" }

3 es的基本操作

3.1 es的結(jié)構(gòu)
3.1.1索引indx,分片,備份
ES服務(wù)中會(huì)創(chuàng)建多個(gè)索引 每個(gè)縮影默認(rèn)被分成5個(gè)分片 每個(gè)分片存在至少一個(gè)備份分片 備份分片 不會(huì)幫助檢索數(shù)據(jù)(當(dāng)ES檢索壓力特別大的時(shí)候才,備份分片才會(huì)幫助檢索數(shù)據(jù)) 備份的分片必須放在不同的服務(wù)器中

3.1.2 類型type
一個(gè)索引下可以創(chuàng)建多個(gè)類型 PS:版本不同,類型的創(chuàng)建也不同

3.1.3 文檔document
一個(gè)類型下可以有多個(gè)文檔,這個(gè)文檔就相當(dāng)于mysql表中的多行數(shù)據(jù)

3.1.4 屬性field

一個(gè)文檔中可以包含多個(gè)屬性,類似于mysql 表中的一行數(shù)據(jù)有多個(gè)列

3.2操作ES的restful語(yǔ)法
GET請(qǐng)求:http://ip:port/index :查詢索引信息http://ip:port/index/type/doc_id :查詢指定的文檔信息 POST請(qǐng)求:http://ip:port/index/type/_search: 查詢文檔,可以在請(qǐng)求體中添加json字符串來(lái)代表查詢條件http://ip:port/index/type/doc_id/_update: 修改文檔,在請(qǐng)求體中添加json字符串來(lái)代表修改的信息 PUT請(qǐng)求:http://ip:port/index : 創(chuàng)建一個(gè)索引,需要在請(qǐng)求體中指定索引的信息http://ip:port/index/type/_mappings:代表創(chuàng)建索引時(shí),指定索引文檔存儲(chǔ)屬性的信息 DELETE 請(qǐng)求:http://ip:port/index: 刪除跑路http://ip:port/index/type/doc_id: 刪除指定的文檔
3.3 索引的操作
3.3.1 創(chuàng)建一個(gè)索引
#創(chuàng)建一個(gè)索引 #number_of_shards 分片 #number_of_replicas 備份 PUT /person {"settings": {"number_of_shards": 5, "number_of_replicas": 1} }
3.3.2 查看一個(gè)索引
1.management2. #查看索引信息 GET /person
3.3.3 刪除 索引
1.management2. #刪除索引 DELETE /person
3.4 ES中Field可以指定的類型

https://www.elastic.co/guide/en/elasticsearch/reference/6.8/mapping-types.html 官方 文檔

字符串類型:text: 一般用于全文檢索,將當(dāng)前field 進(jìn)行分詞keyword:當(dāng)前field 不會(huì)進(jìn)行分詞 數(shù)值類型:long:Intger:short:byte:double:float:half_float: 精度比f(wàn)loat 小一半scaled_float:根據(jù)一個(gè)long 和scaled 來(lái)表達(dá)一個(gè)浮點(diǎn)型 long-345, -scaled 100 ->3.45 時(shí)間類型:date類型,根據(jù)時(shí)間類型指定具體的格式PUT my_index{"mappings": {"_doc": {"properties": {"date": {"type": "date","format": "yyyy-MM-dd HH:mm:ss||yyyy-MM-dd||epoch_millis"}}}}} 布爾類型:boolean 類型,表達(dá)truefalse 二進(jìn)制類型:binary類型暫時(shí)支持Base64編碼的字符串 范圍類型:integer_range:float_range:long_range:賦值時(shí),無(wú)需指定具體的內(nèi)容,只需存儲(chǔ)一個(gè)范圍即可,gte,lte,gt,lt,double_range:date_range:ip_range:PUT range_index{"settings": {"number_of_shards": 2},"mappings": {"_doc": {"properties": {"expected_attendees": {"type": "integer_range"},"time_frame": {"type": "date_range", "format": "yyyy-MM-dd HH:mm:ss||yyyy-MM-dd||epoch_millis"}}}}}PUT range_index/_doc/1?refresh{"expected_attendees" : { "gte" : 10,"lte" : 20},"time_frame" : { "gte" : "2015-10-31 12:00:00", "lte" : "2015-11-01"}} 經(jīng)緯度類型:geo_point:用來(lái)存儲(chǔ)經(jīng)緯度 IP類型:ip:可以存儲(chǔ)IPV4IPV6 其他的數(shù)據(jù)類型,參考官網(wǎng)
3.5 創(chuàng)建索引并指定數(shù)據(jù)結(jié)構(gòu)
#創(chuàng)建索引,指定數(shù)據(jù)類型 PUT /book {"settings": {#分片數(shù)"number_of_shards": 5,#備份數(shù)"number_of_replicas": 1},#指定數(shù)據(jù)類型"mappings": {#類型 Type"novel":{#文檔存儲(chǔ)的field"properties":{#field屬性名"name":{#類型"type":"text",#指定分詞器"analyzer":"ik_max_word",#指定當(dāng)前的field可以被作為查詢的條件"index":true,#是否需要額外存儲(chǔ)"store":false},"author":{"type":"keyword"},"count":{"type":"long"},"on-sale":{"type":"date",#指定時(shí)間類型的格式化方式"format": "yyyy-MM-dd HH:mm:ss||yyyy-MM-dd||epoch_millis"},"descr":{"type":"text","analyzer":"ik_max_word"}}}} }
3.6 文檔操作
文檔在ES服務(wù)中的唯一標(biāo)識(shí), _indx ,_type,_id 三個(gè)內(nèi)容為組合,鎖定一個(gè)文檔,操作時(shí)添加還時(shí)修改操作,
3.6.1 新建文檔
自動(dòng)生成id #添加文檔,自動(dòng)生成id POST /book/novel {"name":"盤(pán)龍","author":"我吃西紅柿","count":100000,"on-sale":"2001-01-01","descr":"大小的血睛鬃毛獅,力大無(wú)窮的紫睛金毛猿,毀天滅地的九頭蛇皇,攜帶著毀滅雷電的恐怖雷龍……這里無(wú)奇不有,這是一個(gè)廣博的魔幻世界。強(qiáng)者可以站在黑色巨龍的頭頂遨游天際,恐怖的魔法可以焚燒江河,可以毀滅城池,可以夷平山岳……" }#添加文檔,手動(dòng)指定id PUT /book/novel/1 {"name":"紅樓夢(mèng)","author":"曹雪芹","count":10000000,"on-sale":"2501-01-01","descr":"中國(guó)古代章回體長(zhǎng)篇小說(shuō),中國(guó)古典四大名著之一,一般認(rèn)為是清代作家曹雪芹所著。小說(shuō)以賈、史、王、薛四大家族的興衰為背景,以富貴公子賈寶玉為視角,以賈寶玉與林黛玉、薛寶釵的愛(ài)情婚姻悲劇為主線,描繪了一批舉止見(jiàn)識(shí)出于須眉之上的閨閣佳人的人生百態(tài),展現(xiàn)了真正的人性美和悲劇美" }
3.6.2 修改文檔

1.覆蓋式修改

#添加文檔,手動(dòng)指定id PUT /book/novel/1 {"name":"紅樓夢(mèng)","author":"曹雪芹","count":1000444,"on-sale":"2501-01-01","descr":"中國(guó)古代章回體長(zhǎng)篇小說(shuō),中國(guó)古典四大名著之一,一般認(rèn)為是清代作家曹雪芹所著。小說(shuō)以賈、史、王、薛四大家族的興衰為背景,以富貴公子賈寶玉為視角,以賈寶玉與林黛玉、薛寶釵的愛(ài)情婚姻悲劇為主線,描繪了一批舉止見(jiàn)識(shí)出于須眉之上的閨閣佳人的人生百態(tài),展現(xiàn)了真正的人性美和悲劇美" }

2.使用doc修改方式

#修改文檔,使用doc 方式 POST /book/novel/1/_update {"doc":{#指定需要修改的field和對(duì)應(yīng)的值"count":566666} }
3.6.3 刪除文檔
#根據(jù)id刪除文檔 DELETE /book/novel/3mEnk3MBaSKoGN4T2olw

4.java 操作ElasticSearch

4.1 java 連接ES
創(chuàng)建maven工程 導(dǎo)入依賴 <!-- 1.elasticsearch--><dependency><groupId>org.elasticsearch</groupId><artifactId>elasticsearch</artifactId><version>6.8.10</version></dependency> <!-- 2.elasticsearch 高級(jí)API--><dependency><groupId>org.elasticsearch.client</groupId><artifactId>elasticsearch-rest-high-level-client</artifactId><version>6.8.10</version></dependency> <!-- 3.junit--><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version></dependency> <!-- 4.lombok--><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.16.22</version></dependency>

創(chuàng)建client鏈接

package com.utils;import org.apache.http.HttpHost; import org.elasticsearch.client.RestClient; import org.elasticsearch.client.RestClientBuilder; import org.elasticsearch.client.RestHighLevelClient;public class EsClient {public static RestHighLevelClient getClient(){// 創(chuàng)建 HttpHostHttpHost httpHost = new HttpHost("127.0.0.1",9200);// 創(chuàng)建 RestClientBuilderRestClientBuilder builder = RestClient.builder(httpHost);// 創(chuàng)建 RestHighLevelClientRestHighLevelClient client = new RestHighLevelClient(builder);return client;} }
4.2創(chuàng)建索引
package com.test;import com.utils.EsClient; import org.elasticsearch.action.admin.indices.create.CreateIndexRequest; import org.elasticsearch.action.admin.indices.create.CreateIndexResponse; import org.elasticsearch.client.RequestOptions; import org.elasticsearch.client.RestHighLevelClient; import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.xcontent.XContentBuilder; import org.elasticsearch.common.xcontent.json.JsonXContent; import org.junit.Test;public class Demo2 {RestHighLevelClient client = EsClient.getClient();String index = "person";String type="man";@Testpublic void createIndx() throws Exception{// 1.準(zhǔn)備關(guān)于索引的settingSettings.Builder settings = Settings.builder().put("number_of_shards", 2).put("number_of_replicas", 1);// 2.準(zhǔn)備關(guān)于索引的mappingXContentBuilder mappings = JsonXContent.contentBuilder().startObject().startObject("properties").startObject("name").field("type", "text").endObject().startObject("age").field("type", "integer").endObject().startObject("birthday").field("type", "date").field("format", "yyyy-MM-dd").endObject().endObject().endObject();// 3.將settings和mappings 封裝到到一個(gè)Request對(duì)象中CreateIndexRequest request = new CreateIndexRequest(index).settings(settings).mapping(type,mappings);// 4.使用client 去連接ESCreateIndexResponse response = client.indices().create(request, RequestOptions.DEFAULT);System.out.println("response:"+response.toString());} }
4.3 檢查索引是否存在,刪除索引
4.3.1 檢查索引存在
package com.test;import com.utils.EsClient; import org.elasticsearch.action.admin.indices.create.CreateIndexRequest; import org.elasticsearch.action.admin.indices.create.CreateIndexResponse; import org.elasticsearch.client.RequestOptions; import org.elasticsearch.client.RestHighLevelClient; import org.elasticsearch.client.indices.GetIndexRequest; import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.xcontent.XContentBuilder; import org.elasticsearch.common.xcontent.json.JsonXContent; import org.junit.Test;import java.io.IOException;public class Demo2 {RestHighLevelClient client = EsClient.getClient();String index = "person";String type="man";@Testpublic void existTest() throws IOException {// 1.準(zhǔn)備request 對(duì)象GetIndexRequest request = new GetIndexRequest(index);// 2.通過(guò)client 去 操作boolean exists = client.indices().exists(request, RequestOptions.DEFAULT);// 3輸出結(jié)果System.out.println(exists);} }
4.3.2 刪除索引
package com.test;import com.utils.EsClient; import org.elasticsearch.action.admin.indices.create.CreateIndexRequest; import org.elasticsearch.action.admin.indices.create.CreateIndexResponse; import org.elasticsearch.action.admin.indices.delete.DeleteIndexRequest; import org.elasticsearch.action.support.master.AcknowledgedResponse; import org.elasticsearch.client.RequestOptions; import org.elasticsearch.client.RestHighLevelClient; import org.elasticsearch.client.indices.GetIndexRequest; import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.xcontent.XContentBuilder; import org.elasticsearch.common.xcontent.json.JsonXContent; import org.junit.Test;import java.io.IOException;public class Demo2 {RestHighLevelClient client = EsClient.getClient();String index = "person";String type="man";@Testpublic void testDelete() throws IOException {// 1.獲取requestDeleteIndexRequest request = new DeleteIndexRequest(index);// 2.使用client 操作requestAcknowledgedResponse delete = client.indices().delete(request, RequestOptions.DEFAULT);// 3.輸出結(jié)果System.out.println(delete.isAcknowledged());} }
4.4 Java操作文檔
4.4.1 添加文檔操作
public class Demo3 {ObjectMapper mapper = new ObjectMapper();RestHighLevelClient client = EsClient.getClient();String index = "person";String type="man";@Testpublic void createDocTest() throws IOException {// 1.準(zhǔn)備一個(gè)json數(shù)據(jù)Person person = new Person(1,"張三",33,new Date());String json = mapper.writeValueAsString(person);// 2.創(chuàng)建一個(gè)request對(duì)象(手動(dòng)指定的方式創(chuàng)建)IndexRequest request = new IndexRequest(index,type,person.getId().toString());request.source(json, XContentType.JSON);// 3.使用client 操作request對(duì)象生成docIndexResponse response = client.index(request, RequestOptions.DEFAULT);// 4.輸出返回結(jié)果System.out.println(response.getResult().toString());} }
4.4.2 修改文檔
public class Demo3 {ObjectMapper mapper = new ObjectMapper();RestHighLevelClient client = EsClient.getClient();String index = "person";String type="man";@Testpublic void updateDocTest() throws Exception{// 1.創(chuàng)建要跟新的MapMap<String,Object> doc = new HashMap<>();doc.put("name","張三三");// 2.創(chuàng)建request, 將doc 封裝進(jìn)去UpdateRequest request = new UpdateRequest(index,type,"1");request.doc(doc);// 3. client 去操作 requestUpdateResponse response = client.update(request, RequestOptions.DEFAULT);// 4.輸出 更新結(jié)果System.out.println(response.getResult());} }
4.4.3 刪除文檔
public class Demo3 {ObjectMapper mapper = new ObjectMapper();RestHighLevelClient client = EsClient.getClient();String index = "person";String type="man";@Testpublic void deleteDocTest() throws Exception{// 1.封裝刪除對(duì)象DeleteRequest request = new DeleteRequest(index,type,"1");// 2 client 操作 request對(duì)象DeleteResponse response = client.delete(request, RequestOptions.DEFAULT);// 3.輸出結(jié)果System.out.println(response.getResult().toString());} }
4.5 java批量操作文檔

批量操作 新增

@Testpublic void bulkCreateDoc() throws Exception{// 1.準(zhǔn)備多個(gè)json 對(duì)象Person p1 = new Person(1,"張三",23,new Date());Person p2 = new Person(2,"里斯",24,new Date());Person p3 = new Person(3,"王武",24,new Date());String json1 = mapper.writeValueAsString(p1);String json2 = mapper.writeValueAsString(p2);String json3 = mapper.writeValueAsString(p3);// 2.創(chuàng)建requestBulkRequest bulkRequest = new BulkRequest();bulkRequest.add(new IndexRequest(index,type,p1.getId().toString()).source(json1,XContentType.JSON)).add(new IndexRequest(index,type,p2.getId().toString()).source(json2,XContentType.JSON)).add(new IndexRequest(index,type,p3.getId().toString()).source(json3,XContentType.JSON));// 3.client 執(zhí)行BulkResponse responses = client.bulk(bulkRequest, RequestOptions.DEFAULT);// 4.輸出結(jié)果System.out.println(responses.getItems().toString());}

批量刪除

public void bulkDelete() throws Exception{// 1.創(chuàng)建Request 對(duì)象BulkRequest bulkRequest = new BulkRequest();bulkRequest.add(new DeleteRequest(index,type,"1"));bulkRequest.add(new DeleteRequest(index,type,"2"));bulkRequest.add(new DeleteRequest(index,type,"3"));// 2.執(zhí)行BulkResponse re = client.bulk(bulkRequest, RequestOptions.DEFAULT);// 3.輸出結(jié)果System.out.println(re.toString());}

5.ES 練習(xí)

索引:sms-logs-index 類型:sms-logs-type

public class Demo4 {ObjectMapper mapper = new ObjectMapper();RestHighLevelClient client = EsClient.getClient();String index = "sms-logs-index";String type="sms-logs-type";@Testpublic void createIndex() throws Exception{// 1.準(zhǔn)備關(guān)于索引的settingSettings.Builder settings = Settings.builder().put("number_of_shards", 3).put("number_of_replicas", 1);// 2.準(zhǔn)備關(guān)于索引的mappingXContentBuilder mappings = JsonXContent.contentBuilder().startObject().startObject("properties").startObject("corpName").field("type", "keyword").endObject().startObject("createDate").field("type", "date").field("format", "yyyy-MM-dd").endObject().startObject("fee").field("type", "long").endObject().startObject("ipAddr").field("type", "ip").endObject().startObject("longCode").field("type", "keyword").endObject().startObject("mobile").field("type", "keyword").endObject().startObject("operatorId").field("type", "integer").endObject().startObject("province").field("type", "keyword").endObject().startObject("replyTotal").field("type", "integer").endObject().startObject("sendDate").field("type", "date").field("format", "yyyy-MM-dd").endObject().startObject("smsContent").field("type", "text").field("analyzer", "ik_max_word").endObject().startObject("state").field("type", "integer").endObject().endObject().endObject();// 3.將settings和mappings 封裝到到一個(gè)Request對(duì)象中CreateIndexRequest request = new CreateIndexRequest(index).settings(settings).mapping(type,mappings);// 4.使用client 去連接ESCreateIndexResponse response = client.indices().create(request, RequestOptions.DEFAULT);System.out.println("response:"+response.toString());}@Testpublic void bulkCreateDoc() throws Exception{// 1.準(zhǔn)備多個(gè)json 對(duì)象String longcode = "1008687";String mobile ="138340658";List<String> companies = new ArrayList<>();companies.add("騰訊課堂");companies.add("阿里旺旺");companies.add("海爾電器");companies.add("海爾智家公司");companies.add("格力汽車");companies.add("蘇寧易購(gòu)");List<String> provinces = new ArrayList<>();provinces.add("北京");provinces.add("重慶");provinces.add("上海");provinces.add("晉城");BulkRequest bulkRequest = new BulkRequest();for (int i = 1; i <16 ; i++) {Thread.sleep(1000);SmsLogs s1 = new SmsLogs();s1.setId(i);s1.setCreateDate(new Date());s1.setSendDate(new Date());s1.setLongCode(longcode+i);s1.setMobile(mobile+2*i);s1.setCorpName(companies.get(i%5));s1.setSmsContent(SmsLogs.doc.substring((i-1)*100,i*100));s1.setState(i%2);s1.setOperatorId(i%3);s1.setProvince(provinces.get(i%4));s1.setIpAddr("127.0.0."+i);s1.setReplyTotal(i*3);s1.setFee(i*6+"");String json1 = mapper.writeValueAsString(s1);bulkRequest.add(new IndexRequest(index,type,s1.getId().toString()).source(json1, XContentType.JSON));System.out.println("數(shù)據(jù)"+i+s1.toString());}// 3.client 執(zhí)行BulkResponse responses = client.bulk(bulkRequest, RequestOptions.DEFAULT);// 4.輸出結(jié)果System.out.println(responses.getItems().toString());} }

6.ElasticSearch的各種查詢

6.1 term 和terms 查詢
6.1.1 term 查詢
term 查詢是代表完全匹配,搜索之前不會(huì)對(duì)你搜索的關(guān)鍵字進(jìn)行分詞,直接拿 關(guān)鍵字 去文檔分詞庫(kù)中匹配內(nèi)容 #term查詢 POST /sms-logs-index/sms-logs-type/_search {#limit ?"from": 0, #limit x,?"size":5,"query": {"term": {"province": {"value": "北京"}}} } public class TermSearch {ObjectMapper mapper = new ObjectMapper();RestHighLevelClient client = EsClient.getClient();String index = "sms-logs-index";String type="sms-logs-type";@Testpublic void termSearchTest() throws IOException {// 1.創(chuàng)建request對(duì)象SearchRequest request = new SearchRequest(index);request.types(type);// 2.創(chuàng)建查詢條件SearchSourceBuilder builder = new SearchSourceBuilder();builder.from(0);builder.size(5);builder.query(QueryBuilders.termQuery("province","北京"));request.source(builder);// 3.執(zhí)行查詢SearchResponse response = client.search(request, RequestOptions.DEFAULT);// 4.輸出查詢結(jié)果for (SearchHit hit : response.getHits().getHits()) {Map<String, Object> sourceAsMap = hit.getSourceAsMap();System.out.println(sourceAsMap);}} }
6.1.2 查詢
terms 和 term 查詢的機(jī)制一樣,搜索之前不會(huì)對(duì)你搜索的關(guān)鍵字進(jìn)行分詞,直接拿 關(guān)鍵字 去文檔分詞庫(kù)中匹配內(nèi)容 terms:是針對(duì)一個(gè)字段包含多個(gè)值 term : where province =北京 terms: where province = 北京 or province =? (類似于mysql 中的 in) 也可針對(duì) text, 只是在分詞庫(kù)中查詢的時(shí)候不會(huì)進(jìn)行分詞 #terms 查詢 POST /sms-logs-index/sms-logs-type/_search {"query": {"terms": {"province": ["北京","晉城"]}} } public class TermSearch {ObjectMapper mapper = new ObjectMapper();RestHighLevelClient client = EsClient.getClient();String index = "sms-logs-index";String type="sms-logs-type";@Testpublic void termsSearchTest() throws IOException {// 1.創(chuàng)建request對(duì)象SearchRequest request = new SearchRequest(index);request.types(type);// 2.創(chuàng)建查詢條件SearchSourceBuilder builder = new SearchSourceBuilder();builder.query(QueryBuilders.termsQuery("province","北京","晉城"));request.source(builder);// 3.執(zhí)行查詢SearchResponse response = client.search(request, RequestOptions.DEFAULT);// 輸出查詢結(jié)果for (SearchHit hit : response.getHits().getHits()) {System.out.println(hit.getSourceAsMap());}} }
6.2 match
match 查詢屬于高級(jí)查詢,會(huì)根據(jù)你查詢字段的類型不一樣,采用不同的查詢方式 查詢的是日期或者數(shù)值,他會(huì)將你基于字符串的查詢內(nèi)容轉(zhuǎn)換為日期或數(shù)值對(duì)待如果查詢的內(nèi)容是一個(gè)不能被分詞的內(nèi)容(keyword),match 不會(huì)將你指定的關(guān)鍵字進(jìn)行分詞如果查詢的內(nèi)容是一個(gè)可以被分詞的內(nèi)容(text),match 查詢會(huì)將你指定的內(nèi)容根據(jù)一定的方式進(jìn)行分詞,去分詞庫(kù)中匹配指定的內(nèi)容 match 查詢,實(shí)際底層就是多個(gè)term 查詢,將多個(gè)term查詢的結(jié)果給你封裝到一起
6.2.1 math_all
查詢?nèi)績(jī)?nèi)容,不指定查詢條件 #match_all 查詢 POST /sms-logs-index/sms-logs-type/_search {"query":{"match_all": {}} } public class MatchSearch {ObjectMapper mapper = new ObjectMapper();RestHighLevelClient client = EsClient.getClient();String index = "sms-logs-index";String type="sms-logs-type";@Testpublic void matchAllSearch() throws IOException {// 1.創(chuàng)建request對(duì)象SearchRequest request = new SearchRequest(index);request.types(type);// 2.創(chuàng)建查詢條件SearchSourceBuilder builder = new SearchSourceBuilder();builder.query(QueryBuilders.matchAllQuery());// ES 默認(rèn)只查詢10條數(shù)據(jù)builder.size(20);request.source(builder);// 3.執(zhí)行查詢SearchResponse response = client.search(request, RequestOptions.DEFAULT);// 4.輸出查詢結(jié)果for (SearchHit hit : response.getHits().getHits()) {System.out.println(hit.getSourceAsMap());}System.out.println(response.getHits().getHits().length);} }
6.2.2 match 查詢

指定一個(gè)field 作為查詢條件

#match 查詢 POST /sms-logs-index/sms-logs-type/_search {"query": {"match": {"smsContent": "偉大戰(zhàn)士"}} } public class MatchSearch {ObjectMapper mapper = new ObjectMapper();RestHighLevelClient client = EsClient.getClient();String index = "sms-logs-index";String type="sms-logs-type";@Testpublic void matchSearch() throws IOException {// 1.創(chuàng)建request對(duì)象SearchRequest request = new SearchRequest(index);request.types(type);// 2.創(chuàng)建查詢條件SearchSourceBuilder builder = new SearchSourceBuilder();//--------------------------------------------------------------builder.query(QueryBuilders.matchQuery("smsContent","偉大戰(zhàn)士"));//--------------------------------------------------------------builder.size(20);request.source(builder);// 3.執(zhí)行查詢SearchResponse response = client.search(request, RequestOptions.DEFAULT);// 4.輸出查詢結(jié)果for (SearchHit hit : response.getHits().getHits()) {System.out.println(hit.getSourceAsMap());}System.out.println(response.getHits().getHits().length);}}
6.2.3 布爾match 查詢
基于一個(gè)field 匹配的內(nèi)容,按照 and 或者or的方式連接 #布爾match查詢 POST /sms-logs-index/sms-logs-type/_search {"query": {"match": {"smsContent": {# 既包含 戰(zhàn)士 也包含 團(tuán)隊(duì)"query": "戰(zhàn)士 團(tuán)隊(duì)","operator": "and"}}} }#布爾match查詢 POST /sms-logs-index/sms-logs-type/_search {"query": {"match": {"smsContent": {# 既包含 戰(zhàn)士 或者 團(tuán)隊(duì)"query": "戰(zhàn)士 團(tuán)隊(duì)","operator": "or"}}} } @Testpublic void booleanMatchSearch() throws IOException {// 1.創(chuàng)建request對(duì)象SearchRequest request = new SearchRequest(index);request.types(type);// 2.創(chuàng)建查詢條件SearchSourceBuilder builder = new SearchSourceBuilder();//--------------------------------------------------------------builder.query(QueryBuilders.matchQuery("smsContent","戰(zhàn)士 團(tuán)隊(duì)").operator(Operator.AND));//--------------------------------------------------------------builder.size(20);request.source(builder);// 3.執(zhí)行查詢SearchResponse response = client.search(request, RequestOptions.DEFAULT);// 4.輸出查詢結(jié)果for (SearchHit hit : response.getHits().getHits()) {System.out.println(hit.getSourceAsMap());}System.out.println(response.getHits().getHits().length);}
6.2.4 multi_match
match 針對(duì)一個(gè)field 做檢索,multi_math 針對(duì)多個(gè)field 進(jìn)行檢索,多個(gè)field對(duì)應(yīng)一個(gè)文本。 #multi_math 查詢 POST /sms-logs-index/sms-logs-type/_search {"query":{"multi_match": {"query": "北京","fields": ["province","smsContent"]}} } public void multiMatchSearch() throws IOException {// 1.創(chuàng)建request對(duì)象SearchRequest request = new SearchRequest(index);request.types(type);// 2.創(chuàng)建查詢條件SearchSourceBuilder builder = new SearchSourceBuilder();//--------------------------------------------------------------builder.query(QueryBuilders.multiMatchQuery("北京","province","smsContent"));//--------------------------------------------------------------builder.size(20);request.source(builder);// 3.執(zhí)行查詢SearchResponse response = client.search(request, RequestOptions.DEFAULT);// 4.輸出查詢結(jié)果for (SearchHit hit : response.getHits().getHits()) {System.out.println(hit.getSourceAsMap());}System.out.println(response.getHits().getHits().length);}
6.3 其他查詢
6.3.1id 查詢
#id 查詢 GET /sms-logs-index/sms-logs-type/1 public class IdGetSearch {ObjectMapper mapper = new ObjectMapper();RestHighLevelClient client = EsClient.getClient();String index = "sms-logs-index";String type="sms-logs-type";@Testpublic void findById() throws IOException {// 創(chuàng)建GetRequest對(duì)象GetRequest request = new GetRequest(index,type,"1");// 執(zhí)行查詢GetResponse response = client.get(request, RequestOptions.DEFAULT);// 輸出結(jié)果System.out.println(response.getSourceAsMap());} }
6.3.2 ids查詢
根據(jù)多個(gè)id 查詢,類似 mysql 中的 where in (id1,id2...) #ids 查詢 POST /sms-logs-index/sms-logs-type/_search {"query": {"ids": {"values": ["1","2","3"]}} } public void findByIds() throws IOException {// 創(chuàng)建request對(duì)象SearchRequest request = new SearchRequest(index);request.types(type);// 指定查詢條件SearchSourceBuilder builder = new SearchSourceBuilder();//--------------------------------------------------builder.query(QueryBuilders.idsQuery().addIds("1","2","3"));//------------------------------------------------------request.source(builder);// 執(zhí)行SearchResponse response = client.search(request, RequestOptions.DEFAULT);// 輸出結(jié)果for (SearchHit hit : response.getHits().getHits()) {System.out.println(hit.getSourceAsMap());}}
6.3.3 prefix 查詢

前綴查詢,可以通過(guò)一個(gè)關(guān)鍵字去指定一個(gè)field 的前綴,從而查詢到指定文檔

#prefix 查詢 POST /sms-logs-index/sms-logs-type/_search {"query": {"prefix": {"corpName": {"value": "海"}}} } #match 查詢 在這里是什么都查不到的 和上邊的prefix 做比較 POST /sms-logs-index/sms-logs-type/_search {"query": {"match": {"corpName": "海"}} } public void findByPrefix() throws IOException {// 創(chuàng)建request對(duì)象SearchRequest request = new SearchRequest(index);request.types(type);// 指定查詢條件SearchSourceBuilder builder = new SearchSourceBuilder();//--------------------------------------------------builder.query(QueryBuilders.prefixQuery("corpName","阿"));//------------------------------------------------------request.source(builder);// 執(zhí)行SearchResponse response = client.search(request, RequestOptions.DEFAULT);// 輸出結(jié)果for (SearchHit hit : response.getHits().getHits()) {System.out.println(hit.getSourceAsMap());}}
6.3.4 fuzzy 查詢
模糊查詢,我們可以輸入一個(gè)字符的大概,ES 可以根據(jù)輸入的大概去匹配內(nèi)容。查詢結(jié)果不穩(wěn)定 #fuzzy 查詢 POST /sms-logs-index/sms-logs-type/_search {"query": {"fuzzy": {"corpName": {"value": "騰訊客堂",#指定前邊幾個(gè)字符是不允許出現(xiàn)錯(cuò)誤的"prefix_length": 2}}} } public void findByFuzzy() throws IOException {// 創(chuàng)建request對(duì)象SearchRequest request = new SearchRequest(index);request.types(type);// 指定查詢條件SearchSourceBuilder builder = new SearchSourceBuilder();//--------------------------------------------------builder.query(QueryBuilders.fuzzyQuery("corpName","騰訊客堂").prefixLength(2));//------------------------------------------------------request.source(builder);// 執(zhí)行SearchResponse response = client.search(request, RequestOptions.DEFAULT);// 輸出結(jié)果for (SearchHit hit : response.getHits().getHits()) {System.out.println(hit.getSourceAsMap());}}
6.3.5 wildcard 查詢
通配查詢,同mysql中的like 是一樣的,可以在查詢時(shí),在字符串中指定通配符*和占位符? #wildcard 查詢 POST /sms-logs-index/sms-logs-type/_search {"query": {"wildcard": {"corpName": {"value": "海爾*"}}} }#wildcard 查詢 POST /sms-logs-index/sms-logs-type/_search {"query": {"wildcard": {"corpName": {"value": "海爾??"}}} } public void findByWildCard() throws IOException {// 創(chuàng)建request對(duì)象SearchRequest request = new SearchRequest(index);request.types(type);// 指定查詢條件SearchSourceBuilder builder = new SearchSourceBuilder();//--------------------------------------------------builder.query(QueryBuilders.wildcardQuery("corpName","海爾*"));//------------------------------------------------------request.source(builder);// 執(zhí)行SearchResponse response = client.search(request, RequestOptions.DEFAULT);// 輸出結(jié)果for (SearchHit hit : response.getHits().getHits()) {System.out.println(hit.getSourceAsMap());}}
6.3.6 rang 查詢

范圍查詢,只針對(duì)數(shù)值類型,對(duì)一個(gè)field 進(jìn)行大于或者小于的范圍指定

#rang 查詢 POST /sms-logs-index/sms-logs-type/_search {"query": {"range": {"fee": {"gte": 10,"lte": 20}}} } public void findByRang() throws IOException {// 創(chuàng)建request對(duì)象SearchRequest request = new SearchRequest(index);request.types(type);// 指定查詢條件SearchSourceBuilder builder = new SearchSourceBuilder();//--------------------------------------------------builder.query(QueryBuilders.rangeQuery("fee").gt(10).lte(30));//------------------------------------------------------request.source(builder);// 執(zhí)行SearchResponse response = client.search(request, RequestOptions.DEFAULT);// 輸出結(jié)果for (SearchHit hit : response.getHits().getHits()) {System.out.println(hit.getSourceAsMap());}}

6.3.7 regexp 查詢

正則查詢,通過(guò)你編寫(xiě)的正則表達(dá)式去匹配內(nèi)容 Ps:prefix wildcard fuzzy 和regexp 查詢效率比較低 ,在要求效率比較高時(shí),避免使用 #regexp 查詢 POST /sms-logs-index/sms-logs-type/_search {"query": {"regexp": {"mobile": "138[0-9]{8}"}} } public void findByRegexp() throws IOException {// 創(chuàng)建request對(duì)象SearchRequest request = new SearchRequest(index);request.types(type);// 指定查詢條件SearchSourceBuilder builder = new SearchSourceBuilder();//--------------------------------------------------builder.query(QueryBuilders.regexpQuery("mobile","138[0-9]{8}"));//------------------------------------------------------request.source(builder);// 執(zhí)行SearchResponse response = client.search(request, RequestOptions.DEFAULT);// 輸出結(jié)果for (SearchHit hit : response.getHits().getHits()) {System.out.println(hit.getSourceAsMap());} }
6.4 深分頁(yè) scrol l
ES 對(duì)from +size時(shí)又限制的,from +size 之和 不能大于1W,超過(guò)后 效率會(huì)十分低下 原理:from+size ES查詢數(shù)據(jù)的方式,第一步將用戶指定的關(guān)鍵詞進(jìn)行分詞,第二部將詞匯去分詞庫(kù)中進(jìn)行檢索,得到多個(gè)文檔id,第三步去各個(gè)分片中拉去數(shù)據(jù), 耗時(shí)相對(duì)較長(zhǎng)第四步根據(jù)score 將數(shù)據(jù)進(jìn)行排序, 耗時(shí)相對(duì)較長(zhǎng)第五步根據(jù)from 和size 的值 將部分?jǐn)?shù)據(jù)舍棄,第六步,返回結(jié)果。scroll +size ES 查詢數(shù)據(jù)的方式第一步將用戶指定的關(guān)鍵詞進(jìn)行分詞,第二部將詞匯去分詞庫(kù)中進(jìn)行檢索,得到多個(gè)文檔id,第三步,將文檔的id放在一個(gè)上下文中第四步,根據(jù)指定的size去ES中檢索指定個(gè)數(shù)數(shù)據(jù),拿完數(shù)據(jù)的文檔id,會(huì)從上下文中移除第五步,如果需要下一頁(yè)的數(shù)據(jù),直接去ES的上下文中找后續(xù)內(nèi)容。第六步,循環(huán)第四步和第五步scroll 不適合做實(shí)時(shí)查詢。 #scroll 查詢,返回第一頁(yè)數(shù)據(jù),并將文檔id信息存放在ES上下文中,并指定生存時(shí)間 POST /sms-logs-index/sms-logs-type/_search?scroll=1m {"query": {"match_all": {}},"size": 2,"sort": [{"fee": {"order": "desc"}}] }#根據(jù)scroll 查詢下一頁(yè)數(shù)據(jù) POST _search/scroll {"scroll_id":"DnF1ZXJ5VGhlbkZldGNoAwAAAAAAABbqFk04VlZ1cjlUU2t1eHpsQWNRY1YwWWcAAAAAAAAW7BZNOFZWdXI5VFNrdXh6bEFjUWNWMFlnAAAAAAAAFusWTThWVnVyOVRTa3V4emxBY1FjVjBZZw==","scroll":"1m" }#刪除scroll上下文中的數(shù)據(jù) DELETE _search/scroll/DnF1ZXJ5VGhlbkZldGNoAwAAAAAAABchFk04VlZ1cjlUU2t1eHpsQWNRY1YwWWcAAAAAAAAXIBZNOFZWdXI5VFNrdXh6bEFjUWNWMFlnAAAAAAAAFx8WTThWVnVyOVRTa3V4emxBY1FjVjBZZw== public class ScrollSearch {ObjectMapper mapper = new ObjectMapper();RestHighLevelClient client = EsClient.getClient();String index = "sms-logs-index";String type="sms-logs-type";@Testpublic void scrollSearch() throws IOException {// 1.創(chuàng)建requestSearchRequest searchRequest = new SearchRequest(index);searchRequest.types(type);// 2.指定scroll信息,過(guò)期時(shí)間searchRequest.scroll(TimeValue.timeValueMinutes(1L));// 3.指定查詢條件SearchSourceBuilder builder = new SearchSourceBuilder();builder.size(4);builder.sort("fee", SortOrder.DESC);searchRequest.source(builder);// 4.獲取返回結(jié)果scrollId,獲取sourceSearchResponse response = client.search(searchRequest, RequestOptions.DEFAULT);String scrollId = response.getScrollId();System.out.println("-------------首頁(yè)數(shù)據(jù)---------------------");for (SearchHit hit : response.getHits().getHits()) {System.out.println(hit.getSourceAsMap());}while (true){// 5.創(chuàng)建scroll requestSearchScrollRequest scrollRequest = new SearchScrollRequest(scrollId);// 6.指定scroll 有效時(shí)間scrollRequest.scroll(TimeValue.timeValueMinutes(1L));// 7.執(zhí)行查詢,返回查詢結(jié)果SearchResponse scroll = client.scroll(scrollRequest, RequestOptions.DEFAULT);// 8.判斷是否查詢到數(shù)據(jù),查詢到輸出SearchHit[] searchHits = scroll.getHits().getHits();if(searchHits!=null && searchHits.length >0){System.out.println("-------------下一頁(yè)數(shù)據(jù)---------------------");for (SearchHit hit : searchHits) {System.out.println(hit.getSourceAsMap());}}else{// 9.沒(méi)有數(shù)據(jù),結(jié)束System.out.println("-------------結(jié)束---------------------");break;}}// 10.創(chuàng)建 clearScrollRequestClearScrollRequest clearScrollRequest = new ClearScrollRequest();// 11.指定scrollIdclearScrollRequest.addScrollId(scrollId);//12.刪除scrollClearScrollResponse clearScrollResponse = client.clearScroll(clearScrollRequest, RequestOptions.DEFAULT);// 13.輸出結(jié)果System.out.println("刪除scroll:"+clearScrollResponse.isSucceeded());} }
6.5 delete-by-query
根據(jù)term,match 等查詢方式去刪除大量索引 PS:如果你要?jiǎng)h除的內(nèi)容,時(shí)index下的大部分?jǐn)?shù)據(jù),推薦創(chuàng)建一個(gè)新的index,然后把保留的文檔內(nèi)容,添加到全新的索引 #Delet-by-query 刪除 POST /sms-logs-index/sms-logs-type/_delete_by_query {"query": {"range": {"fee": {"lt": 20}}} } public void deleteByQuery() throws IOException {// 1.創(chuàng)建DeleteByQueryRequestDeleteByQueryRequest request = new DeleteByQueryRequest(index);request.types(type);// 2.指定條件request.setQuery(QueryBuilders.rangeQuery("fee").lt(20));// 3.執(zhí)行BulkByScrollResponse response = client.deleteByQuery(request, RequestOptions.DEFAULT);// 4.輸出返回結(jié)果System.out.println(response.toString());}
6.6 復(fù)合查詢
復(fù)合過(guò)濾器,將你的多個(gè)查詢條件 以一定的邏輯組合在一起,must:所有條件組合在一起,表示 and 的意思 must_not: 將must_not中的條件,全部都不匹配,表示not的意思 should:所有條件用should 組合在一起,表示or 的意思 #省是 晉城 或者北京 # 運(yùn)營(yíng)商不能是聯(lián)通 #smsContent 包含 戰(zhàn)士 和的 POST /sms-logs-index/sms-logs-type/_search {"query": {"bool": {"should": [{"term": {"province": {"value": "晉城"}}},{"term": {"province": {"value": "北京"}}}],"must_not": [{"term": {"operatorId": {"value": "2"}}}],"must": [{"match": {"smsContent": "戰(zhàn)士"}},{"match": {"smsContent": "的"}}]}} } public void boolSearch() throws IOException {// 1.創(chuàng)建 searchRequestSearchRequest request = new SearchRequest(index);request.types(type);// 2.指定查詢條件SearchSourceBuilder builder = new SearchSourceBuilder();BoolQueryBuilder boolQueryBuilder = new BoolQueryBuilder();// #省是 晉城 或者北京boolQueryBuilder.should(QueryBuilders.termQuery("province","北京"));boolQueryBuilder.should(QueryBuilders.termQuery("province","晉城"));//# 運(yùn)營(yíng)商不能是聯(lián)通boolQueryBuilder.mustNot(QueryBuilders.termQuery("operatorId",2));//#smsContent 包含 戰(zhàn)士 和的boolQueryBuilder.must(QueryBuilders.matchQuery("smsContent","戰(zhàn)士"));boolQueryBuilder.must(QueryBuilders.matchQuery("smsContent","的"));builder.query(boolQueryBuilder);request.source(builder);// 3.執(zhí)行查詢SearchResponse response = client.search(request, RequestOptions.DEFAULT);// 4.輸出結(jié)果for (SearchHit hit : response.getHits().getHits()) {System.out.println(hit.getSourceAsMap());}}
6.6.2 boosting 查詢
boosting 查詢可以幫助我們?nèi)ビ绊懖樵兒蟮膕corepositive:只有匹配上positive 查詢的內(nèi)容,才會(huì)被放到返回的結(jié)果集中negative: 如果匹配上了positive 也匹配上了negative, 就可以 降低這樣的文檔score.negative_boost:指定系數(shù),必須小于1 0.5 關(guān)于查詢時(shí),分?jǐn)?shù)時(shí)如何計(jì)算的:搜索的關(guān)鍵字再文檔中出現(xiàn)的頻次越高,分?jǐn)?shù)越高指定的文檔內(nèi)容越短,分?jǐn)?shù)越高。我們?cè)偎阉鲿r(shí),指定的關(guān)鍵字也會(huì)被分詞,這個(gè)被分詞的內(nèi)容,被分詞庫(kù)匹配的個(gè)數(shù)越多,分?jǐn)?shù)就越高。 #boosting 查詢 POST /sms-logs-index/sms-logs-type/_search {"query": {"boosting": {"positive": {"match": {"smsContent": "戰(zhàn)士"}}, "negative": {"match": {"smsContent": "團(tuán)隊(duì)"}},"negative_boost": 0.2}} } public void boostSearch() throws IOException {// 1.創(chuàng)建 searchRequestSearchRequest request = new SearchRequest(index);request.types(type);// 2.指定查詢條件SearchSourceBuilder builder = new SearchSourceBuilder();BoostingQueryBuilder boost = QueryBuilders.boostingQuery(QueryBuilders.matchQuery("smsContent", "戰(zhàn)士"),QueryBuilders.matchQuery("smsContent", "團(tuán)隊(duì)")).negativeBoost(0.2f);builder.query(boost);request.source(builder);// 3.執(zhí)行查詢SearchResponse response = client.search(request, RequestOptions.DEFAULT);// 4.輸出結(jié)果for (SearchHit hit : response.getHits().getHits()) {System.out.println(hit.getSourceAsMap());}}
6.7 filter 查詢

query 查詢:根據(jù)你的查詢條件,去計(jì)算文檔的匹配度得到一個(gè)分?jǐn)?shù),并根據(jù)分?jǐn)?shù)排序,不會(huì)做緩存的。

filter 查詢:根據(jù)查詢條件去查詢文檔,不去計(jì)算分?jǐn)?shù),而且filter會(huì)對(duì)經(jīng)常被過(guò)濾的數(shù)據(jù)進(jìn)行緩存。

#filter 查詢 POST /sms-logs-index/sms-logs-type/_search {"query": {"bool": {"filter": [{"term": {"corpName": "海爾智家公司"}},{"range":{"fee":{"lte":50}}}]}} } public void filter() throws IOException {// 1.searchRequestSearchRequest searchRequest = new SearchRequest(index);searchRequest.types(type);// 2.指定查詢條件SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();BoolQueryBuilder boolBuilder = QueryBuilders.boolQuery();boolBuilder.filter(QueryBuilders.termQuery("corpName","海爾智家公司"));boolBuilder.filter(QueryBuilders.rangeQuery("fee").gt(20));sourceBuilder.query(boolBuilder);searchRequest.source(sourceBuilder);// 3.執(zhí)行SearchResponse response = client.search(searchRequest, RequestOptions.DEFAULT);// 4. 輸出結(jié)果for (SearchHit hit : response.getHits().getHits()) {System.out.println(hit.getSourceAsMap());System.out.println(hit.getId()+"的分?jǐn)?shù)是:"+hit.getScore());}}
6.8 高亮查詢
高亮查詢就是用戶輸入的關(guān)鍵字,以一定特殊樣式展示給用戶,讓用戶知道為什么這個(gè)結(jié)果被檢索出來(lái) 高亮展示的數(shù)據(jù),本身就是文檔中的一個(gè)field,單獨(dú)將field以highlight的形式返回給用戶 ES提供了一個(gè)highlight 屬性,他和query 同級(jí)別。frament_size: 指定高亮數(shù)據(jù)展示多少個(gè)字符回來(lái)pre_tags:指定前綴標(biāo)簽<front color="red">post_tags:指定后綴標(biāo)簽 </font> #highlight 高亮查詢 POST /sms-logs-index/sms-logs-type/_search {"query": {"match": {"smsContent": "團(tuán)隊(duì)"}},"highlight": {"fields": {"smsContent":{}},"pre_tags":"<font color='red'>","post_tags":"</font>","fragment_size":10} } public void highLightQuery() throws IOException {// 1.創(chuàng)建requestSearchRequest request = new SearchRequest(index);request.types(type);// 2.指定查詢條件,指定高亮SearchSourceBuilder builder = new SearchSourceBuilder();builder.query(QueryBuilders.matchQuery("smsContent","團(tuán)隊(duì)"));HighlightBuilder highlightBuilder = new HighlightBuilder();highlightBuilder.field("smsContent",10).preTags("<font colr='red'>").postTags("</font>");builder.highlighter(highlightBuilder);request.source(builder);// 3.執(zhí)行SearchResponse response = client.search(request, RequestOptions.DEFAULT);//4. 輸出結(jié)果for (SearchHit hit : response.getHits().getHits()) {System.out.println(hit.getHighlightFields().get("smsContent"));}}
6.9 聚合查詢
ES的聚合查詢和mysql 的聚合查詢類似,ES的聚合查詢相比mysql 要強(qiáng)大得多。ES提供的統(tǒng)計(jì)數(shù)據(jù)的方式多種多樣。 #ES 聚合查詢的RSTFul 語(yǔ)法 POST /index/type/_search {"aggs":{"(名字)agg":{"agg_type":{"屬性""值"}}} }
6.9.1 去重計(jì)數(shù)聚合查詢
去重計(jì)數(shù),cardinality 先將返回的文檔中的一個(gè)指定的field進(jìn)行去重,統(tǒng)計(jì)一共有多少條 # 去重計(jì)數(shù) 查詢 province POST /sms-logs-index/sms-logs-type/_search {"aggs": {"provinceAgg": {"cardinality": {"field": "province"}}} } public void aggCardinalityC() throws IOException {// 1.創(chuàng)建requestSearchRequest request = new SearchRequest(index);request.types(type);// 2. 指定使用聚合查詢方式SearchSourceBuilder builder = new SearchSourceBuilder();builder.aggregation(AggregationBuilders.cardinality("provinceAgg").field("province"));request.source(builder);// 3.執(zhí)行查詢SearchResponse response = client.search(request, RequestOptions.DEFAULT);// 4.輸出返回結(jié)果Cardinality agg = response.getAggregations().get("provinceAgg");System.out.println(agg.getValue());}
6.9.2 范圍統(tǒng)計(jì)
統(tǒng)計(jì)一定范圍內(nèi)出現(xiàn)的文檔個(gè)數(shù),比如,針對(duì)某一個(gè)field 的值再0~100,100~200,200~300 之間文檔出現(xiàn)的個(gè)數(shù)分別是多少 范圍統(tǒng)計(jì) 可以針對(duì) 普通的數(shù)值,針對(duì)時(shí)間類型,針對(duì)ip類型都可以響應(yīng)。 數(shù)值 rang 時(shí)間 date_rang ip ip_rang #針對(duì)數(shù)值方式的范圍統(tǒng)計(jì) from 帶等于效果 ,to 不帶等于效果 POST /sms-logs-index/sms-logs-type/_search {"aggs": {"agg": {"range": {"field": "fee","ranges": [{"to": 30},{"from": 30,"to": 60},{"from": 60}]}}} } #時(shí)間方式統(tǒng)計(jì) POST /sms-logs-index/sms-logs-type/_search {"aggs": {"agg": {"date_range": {"field": "sendDate","format": "yyyy", "ranges": [{"to": "2000"},{"from": "2000"}]}}} } #ip 方式 范圍統(tǒng)計(jì) POST /sms-logs-index/sms-logs-type/_search {"aggs": {"agg": {"ip_range": {"field": "ipAddr","ranges": [{"to": "127.0.0.8"},{"from": "127.0.0.8"}]}}} } public void aggRang() throws IOException {// 1.創(chuàng)建requestSearchRequest request = new SearchRequest(index);request.types(type);// 2. 指定使用聚合查詢方式SearchSourceBuilder builder = new SearchSourceBuilder();builder.aggregation(AggregationBuilders.range("agg").field("fee").addUnboundedTo(30).addRange(30,60).addUnboundedFrom(60));request.source(builder);// 3.執(zhí)行查詢SearchResponse response = client.search(request, RequestOptions.DEFAULT);// 4.輸出返回結(jié)果Range agg = response.getAggregations().get("agg");for (Range.Bucket bucket : agg.getBuckets()) {String key = bucket.getKeyAsString();Object from = bucket.getFrom();Object to = bucket.getTo();long docCount = bucket.getDocCount();System.out.println(String.format("key: %s ,from: %s ,to: %s ,docCount: %s",key,from,to,docCount));}}
6.9.3 統(tǒng)計(jì)聚合
他可以幫你查詢指定field 的最大值,最小值,平均值,平方和... 使用 extended_stats #統(tǒng)計(jì)聚合查詢 extended_stats POST /sms-logs-index/sms-logs-type/_search {"aggs": {"agg": {"extended_stats": {"field": "fee"}}} } // java實(shí)現(xiàn) public void aggExtendedStats() throws IOException {// 1.創(chuàng)建requestSearchRequest request = new SearchRequest(index);request.types(type);// 2. 指定使用聚合查詢方式SearchSourceBuilder builder = new SearchSourceBuilder();builder.aggregation(AggregationBuilders.extendedStats("agg").field("fee"));request.source(builder);// 3.執(zhí)行查詢SearchResponse response = client.search(request, RequestOptions.DEFAULT);// 4.輸出返回結(jié)果ExtendedStats extendedStats = response.getAggregations().get("agg");System.out.println("最大值:"+extendedStats.getMaxAsString()+",最小值:"+extendedStats.getMinAsString());}
6.9.4 其他聚合查詢 查看官方文檔

https://www.elastic.co/guide/en/elasticsearch/reference/6.8/search-aggregations-metrics-weight-avg-aggregation.html

6.10 地圖經(jīng)緯度搜索
#創(chuàng)建一個(gè)經(jīng)緯度索引,指定一個(gè) name ,一個(gè)location PUT /map {"settings": {"number_of_shards": 5,"number_of_replicas": 1},"mappings": {"map":{"properties":{"name":{"type":"text"},"location":{"type":"geo_point"}}}} }#添加測(cè)試數(shù)據(jù) PUT /map/map/1 {"name":"天安門(mén)","location":{"lon": 116.403694,"lat":39.914492} }PUT /map/map/2 {"name":"百望山","location":{"lon": 116.26284,"lat":40.036576} }PUT /map/map/3 {"name":"北京動(dòng)物園","location":{"lon": 116.347352,"lat":39.947468} }
6.10.1 ES 的地圖檢索方式
geo_distance :直線距離檢索方式 geo_bounding_box:2個(gè)點(diǎn)確定一個(gè)矩形,獲取再矩形內(nèi)的數(shù)據(jù) geo_polygon:以多個(gè)點(diǎn),確定一個(gè)多邊形,獲取多邊形的全部數(shù)據(jù)
6.10.2 基于RESTFul 實(shí)現(xiàn)地圖檢索

geo_distance

#geo_distance POST /map/map/_search {"query": {"geo_distance":{#確定一個(gè)點(diǎn)"location":{"lon":116.434739,"lat":39.909843},#確定半徑"distance":20000,#指定形狀為圓形"distance_type":"arc"}} } #geo_bounding_box POST /map/map/_search {"query":{"geo_bounding_box":{"location":{"top_left":{"lon":116.327805,"lat":39.95499},"bottom_right":{"lon": 116.363162,"lat":39.938395}}}} } #geo_polygon POST /map/map/_search {"query":{"geo_polygon":{"location":{# 指定多個(gè)點(diǎn)確定 位置"points":[{"lon":116.220296,"lat":40.075013},{"lon":116.346777,"lat":40.044751},{"lon":116.236106,"lat":39.981533} ]}}} }
6.10.3 java 實(shí)現(xiàn) geo_polygon
public class GeoDemo {RestHighLevelClient client = EsClient.getClient();String index = "map";String type="map";@Testpublic void GeoPolygon() throws IOException {// 1.創(chuàng)建searchRequestSearchRequest request = new SearchRequest(index);request.types(type);// 2.指定 檢索方式SearchSourceBuilder builder = new SearchSourceBuilder();List<GeoPoint> points = new ArrayList<>();points.add(new GeoPoint(40.075013,116.220296));points.add(new GeoPoint(40.044751,116.346777));points.add(new GeoPoint(39.981533,116.236106));builder.query(QueryBuilders.geoPolygonQuery("location",points));request.source(builder);// 3.執(zhí)行SearchResponse response = client.search(request, RequestOptions.DEFAULT);// 4.輸出結(jié)果for (SearchHit hit : response.getHits().getHits()) {System.out.println(hit.getSourceAsMap());}} }

總結(jié)

以上是生活随笔為你收集整理的听某个老师的ElasticSearch记的笔记了的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

国产成人一区二区三区在线观看 | 国产成人无码AⅤ片在线观 日韩av不卡在线 | 色综合久久五月天 | 亚洲国产欧洲综合997久久, | 欧美日韩一区三区 | 精品久久综合 | 国产精品毛片久久 | 色综合天天综合在线视频 | 亚洲va欧美va | 久久99热精品 | 免费久久99精品国产婷婷六月 | 不卡的av| 欧美视频二区 | www.99在线观看 | 精品国产成人在线影院 | 国产精品美女久久 | 五月天开心| 六月丁香六月婷婷 | av不卡中文字幕 | 久久久久久久久久久久久9999 | 亚洲精品乱码久久久久 | 香蕉在线影院 | 开心激情五月婷婷 | 免费视频一二三 | 成人av在线影视 | 丰满少妇对白在线偷拍 | 欧美国产大片 | 亚洲精品在线视频网站 | 欧美亚洲一区二区在线 | 欧美日韩一区二区久久 | 丁香六月五月婷婷 | 久久精品影片 | 九七人人干 | 色99在线| 国产又粗又猛又色又黄视频 | 四虎8848免费高清在线观看 | 久久精品站 | 成人免费亚洲 | 国产又粗又长的视频 | 久久久久久久久久久久久9999 | www.久草视频| 色网站免费在线观看 | 开心色婷婷 | 日韩免费三区 | 日韩高清av | 日韩高清精品一区二区 | 97电影在线观看 | 五月天久久狠狠 | 69视频在线播放 | 成人宗合网 | 成年人免费在线观看网站 | 成年人在线免费看 | 亚洲国产日韩欧美 | 2023亚洲精品国偷拍自产在线 | 国产精品黄色av | 一本色道久久综合亚洲二区三区 | 天天艹| 日韩在线观看精品 | 激情图片久久 | 亚洲国产精品免费 | 亚洲专区视频在线观看 | 国产精品手机在线 | 91激情视频在线观看 | 国产精品久久久av久久久 | 字幕网在线观看 | 国产精品四虎 | 欧美日韩性 | 久草国产精品 | 中国成人一区 | 国产精品久久久久久久久久三级 | av官网| 91视频成人免费 | 99热最新地址 | 午夜视频久久久 | 国产福利一区二区三区在线观看 | 四季av综合网站 | 色综合天天 | 中文字幕av免费在线观看 | 国产一区播放 | 麻豆视频在线观看免费 | 免费看污片 | 手机成人在线电影 | 日韩在线视频观看免费 | 欧美日韩亚洲在线观看 | 国产精品青草综合久久久久99 | 婷婷深爱五月 | 精品视频在线看 | 蜜桃av观看 | 一本—道久久a久久精品蜜桃 | 国内精品久久久精品电影院 | 日韩有码第一页 | 97av在线视频免费播放 | 成 人 黄 色 视频 免费观看 | 久久新视频 | 日本精品在线 | 国产精品视频在线观看 | 狠狠综合网 | 96视频在线| 爱干视频| 精品一区二区久久久久久久网站 | 91免费看黄色| 成年人在线观看网站 | 丁香激情综合久久伊人久久 | 国产日韩精品一区二区三区 | 狠狠色噜噜狠狠狠狠 | 在线观看免费黄色 | www亚洲国产 | 97超碰国产精品 | 91成人精品视频 | 五月婷婷中文 | 午夜男人影院 | 日韩一区二区三区高清在线观看 | 日本三级全黄少妇三2023 | 在线观看韩日电影免费 | 开心色婷婷| 中午字幕在线 | 91网站观看 | 91精彩视频 | 精品夜夜嗨av一区二区三区 | 欧洲精品视频一区二区 | 色九九视频| 国产自在线观看 | 国产精品99久久久精品 | 欧美日韩激情视频8区 | 韩国一区二区三区视频 | 在线观看中文 | 狠狠躁夜夜躁人人爽超碰91 | 香蕉视频在线免费看 | 久久成人精品电影 | 日韩免费在线播放 | 天天综合中文 | 在线观看国产www | 伊人狠狠| 国产最新在线视频 | 国产精品手机在线观看 | 欧美中文字幕第一页 | 国产精品6999成人免费视频 | 精品亚洲成人 | 国产黄色精品视频 | 黄色三级久久 | 九九热精品视频在线观看 | 人人玩人人添人人 | 丝袜美腿av | 欧美一级视频免费看 | 精品国产欧美一区二区三区不卡 | 日韩av不卡播放 | 国产精品国产三级国产 | 中文字幕中文字幕中文字幕 | 91av视频观看 | 免费看亚洲毛片 | 婷婷色婷婷 | 热久久在线视频 | 久久精品99国产 | 国产视频1区2区3区 久久夜视频 | 天天干天天干天天射 | 91成人免费观看视频 | 福利区在线观看 | 国内精品中文字幕 | 亚洲精品91天天久久人人 | 欧美福利视频 | 国产美女网站在线观看 | 97在线免费观看 | 久久超碰网| 一级久久精品 | 国产亚洲精品av | 欧美一二三视频 | 又色又爽又黄 | 久久精品国产久精国产 | 亚洲aⅴ在线 | 欧美性天天 | 国产日韩在线播放 | 欧美激情另类文学 | 久久久久久久久久影视 | 国产精品久久久久毛片大屁完整版 | 中国一级片免费看 | 亚洲第一中文网 | 中文字幕一区二区三区在线播放 | 天天爽天天搞 | 久草网视频在线观看 | 日本爱爱片| 免费观看国产成人 | 精品国产一区二区久久 | 国产 视频 久久 | 精品视频免费观看 | 99在线热播 | 综合久久精品 | 精品一区二区三区香蕉蜜桃 | 黄色美女免费网站 | 亚洲欧美日本A∨在线观看 青青河边草观看完整版高清 | 亚洲精品视频在线观看网站 | 天天操天天操天天操天天 | 欧美精品久 | 亚洲精品大全 | 久久一本综合 | 综合网av| 久久观看| 国产又粗又硬又爽的视频 | 亚洲精品视频在线免费播放 | 国产69精品久久久久久久久久 | 国产高清不卡 | 国产喷水在线 | av免费观看高清 | 日本女人在线观看 | 热久久视久久精品18亚洲精品 | 精品国产一区二区三区四区vr | 男女激情免费网站 | 99婷婷狠狠成为人免费视频 | 国产精品不卡 | 国产在线中文字幕 | 色婷婷电影 | 日日夜夜天天 | 色噜噜日韩精品一区二区三区视频 | 亚洲天堂网视频在线观看 | 精品亚洲男同gayvideo网站 | 婷婷中文字幕在线观看 | 97视频资源| 在线国产能看的 | 久久久久久国产精品亚洲78 | 狠狠干电影 | 国产精品电影一区二区 | 中文欧美字幕免费 | 国产精品久久久久久久久婷婷 | 狠狠夜夜 | 欧美激情一区不卡 | 国产精彩视频一区 | 免费观看视频黄 | 免费在线观看黄色网 | 国产精品麻豆视频 | 日韩理论片| 少妇bbw撒尿| 久久成视频 | 91精品国产综合久久久久久久 | 国产香蕉97碰碰久久人人 | 久久视频在线观看免费 | 亚洲国产精品成人va在线观看 | 国产成人精品不卡 | 国产明星视频三级a三级点| 一级免费黄色 | 九九热在线视频免费观看 | 亚洲精品视频在 | 色婷婷av一区 | 婷婷久月 | 黄p网站在线观看 | 久久综合干| 久久免费视频在线 | 欧美最新另类人妖 | 亚洲精品天天 | 国产精品岛国久久久久久久久红粉 | 亚洲激情一区二区三区 | 国产高清视频在线免费观看 | av在线在线 | 亚洲91网站 | 在线国产日韩 | 九色在线视频 | 深夜免费福利视频 | 一本—道久久a久久精品蜜桃 | 成人在线免费小视频 | 中文字幕在线播放一区二区 | 美女免费黄视频网站 | 成人免费xxxxxx视频 | 久久精品女人毛片国产 | 久久www免费人成看片高清 | 国产无套精品久久久久久 | 免费一级黄色 | 久久久久草 | 超碰97在线看 | 亚洲欧美日韩一级 | 91在线视频导航 | 亚洲精品高清在线 | 国产精品久久久久久久久久妇女 | 六月色婷婷 | 成人黄色国产 | 国产我不卡 | 丁香综合网 | 亚洲精品在线视频播放 | 一级黄色片在线观看 | 男女免费av | 国产精品久久久久久久久久 | 黄网站免费大全入口 | 欧美日韩高清一区二区 国产亚洲免费看 | 日韩激情第一页 | 五月激情视频 | 色婷婷狠狠18 | 国产精品一二 | 中文字幕在线免费观看视频 | 麻豆视频在线免费看 | 91在线国产观看 | 亚洲一区二区三区毛片 | www亚洲视频 | 亚洲精品视频在线观看免费视频 | 日本韩国精品一区二区在线观看 | 欧美成人性网 | 久久久国产电影 | 国产午夜三级一区二区三桃花影视 | 91av视频网站 | 国产精品久久 | 国产破处在线播放 | 成人一级片在线观看 | 精品国自产在线观看 | 亚洲视频精选 | 人人cao| 99精品久久久久久久 | 国产成人精品一区二区三区免费 | 国产一区二区三区在线免费观看 | 人人爽人人射 | 色婷av| 亚洲韩国一区二区三区 | 成人精品一区二区三区中文字幕 | 久久精品视频免费观看 | 日本精品久久久久影院 | 国产精品99久久久久久大便 | 91秒拍国产福利一区 | 日韩在线观看视频在线 | 中文字幕在线不卡国产视频 | jizzjizzjizz亚洲 | 亚洲一二区视频 | 久久99精品久久只有精品 | 国产护士hd高朝护士1 | 在线观看国产永久免费视频 | 久久久久日本精品一区二区三区 | 久久黄视频 | 国产福利av | 500部大龄熟乱视频使用方法 | 狠狠干天天 | 亚洲精品久久激情国产片 | 中文字幕在线观看免费高清完整版 | 99这里只有久久精品视频 | 国产69精品久久久久久久久久 | 久久视频国产 | 狠狠狠狠狠色综合 | 日本精品视频在线播放 | 婷婷去俺也去六月色 | 夜夜操狠狠干 | 女人高潮一级片 | 五月天国产精品 | 日韩中文在线播放 | 亚洲成av人影院 | 在线免费黄色av | 国内精品久久久久影院一蜜桃 | 在线观看国产中文字幕 | 欧美精品乱码99久久影院 | 8090yy亚洲精品久久 | 国产精品毛片久久久久久久 | 欧美综合久久 | 亚洲香蕉视频 | 亚洲午夜av | 久久久www成人免费精品张筱雨 | 国产在线观 | 成人三级网站在线观看 | 97在线免费观看视频 | 在线视频手机国产 | 久久久免费看视频 | 精品国产成人av在线免 | 久日精品 | 99这里只有精品99 | 国产精品久久久777 成人手机在线视频 | 最新影院 | 欧美一级特黄高清视频 | 天天摸日日摸人人看 | 狠狠狠狠狠操 | 欧美a级免费视频 | 麻豆91在线看 | 日韩 精品 一区 国产 麻豆 | 国产成人av电影在线观看 | 亚洲成av人片 | 亚洲综合成人婷婷小说 | 亚洲伊人色 | 国产尤物一区二区三区 | 亚洲精品小视频在线观看 | 黄网站色视频 | 韩国精品一区二区三区六区色诱 | 国产精品免费看久久久8精臀av | 最新日韩中文字幕 | 日韩在线视频免费看 | www久久久 | 天天色天天操天天爽 | 国产成免费视频 | 91精品国产99久久久久久红楼 | 四虎成人免费影院 | 人人玩人人添人人澡超碰 | 高清av免费观看 | 激情五月婷婷综合 | 国产精品久久久久影视 | 亚洲黄色免费 | 永久免费的啪啪网站免费观看浪潮 | 国产精品自拍av | 成年人三级网站 | www免费看片com | 久久久精品二区 | 日韩美视频 | av免费黄色 | 草久视频在线观看 | 人人干狠狠操 | 国产免费av一区二区三区 | 欧美一区三区四区 | 欧美一级免费片 | 夜色资源站国产www在线视频 | 成人av电影网址 | 日韩欧美精品在线观看视频 | 干狠狠| 国产亚洲精品bv在线观看 | 91久久久久久国产精品 | 精品麻豆入口免费 | 国产 日韩 欧美 自拍 | 天天曰天天曰 | 久久a级片 | 久久人人爽人人爽人人 | 精品久久电影 | 天天舔天天射天天操 | 日韩电影在线一区二区 | 亚洲成人av在线 | 日韩免费在线看 | av免费电影在线观看 | 成人黄色片在线播放 | 亚洲成人av一区 | 国产中文伊人 | 免费视频97 | 国产精品激情在线观看 | 国产99久久久国产精品免费二区 | 最新av观看 | 国产一二三区av | 午夜精品久久久久 | 高清av在线| 午夜精品剧场 | 欧美日韩一区二区免费在线观看 | 国内精品久久天天躁人人爽 | 五月天综合婷婷 | 射久久久 | 色偷偷网站视频 | 欧美性爽爽 | 黄在线 | 激情在线免费视频 | 天天色天天射天天干 | 亚洲精品美女在线观看 | 久久这里有 | 亚洲日本精品 | 国产精品欧美日韩在线观看 | 国产精品女教师 | 久久久久国产精品免费免费搜索 | 亚洲精品女人久久久 | 欧美一二三区在线观看 | 夜夜躁狠狠燥 | 国产特级毛片aaaaaaa高清 | 天天干天天干天天干天天干天天干天天干 | 久久久免费视频播放 | 日韩av片免费在线观看 | 激情欧美在线观看 | 亚洲激情在线视频 | 国产精品永久久久久久久www | 五月婷婷六月丁香 | 久久精品国产亚洲精品2020 | 久久精品人人做人人综合老师 | 91精品国自产在线观看 | 婷婷香蕉| 97精品视频在线播放 | 91在线国内视频 | 涩涩伊人 | 91在线超碰 | av综合av | 国产成人精品av在线 | 国产专区视频在线观看 | 成人天堂网 | 麻豆一级视频 | 麻豆视频91 | 欧美伦理电影一区二区 | 麻豆一区在线观看 | 成全在线视频免费观看 | 亚洲aⅴ在线 | 在线播放一区二区三区 | 在线看片日韩 | 亚洲视频一区二区三区在线观看 | 亚洲精品婷婷 | 99久久精品国产一区 | 人人澡人摸人人添学生av | 亚洲欧洲在线视频 | 久久国内精品99久久6app | 天天操天天干天天操天天干 | 国产精品欧美久久久久无广告 | 伊人伊成久久人综合网站 | 99久久婷婷国产综合亚洲 | 国产精品中文字幕av | 一本到视频在线观看 | 黄色aaa级片 | 国产精品久久久久三级 | 男女日麻批 | 久久精品99国产精品 | 婷婷亚洲五月色综合 | 一区二区三区在线电影 | 午夜视频色 | 激情综合五月网 | 国产亚洲视频在线免费观看 | 91成人破解版| 亚洲国产视频网站 | 日韩视频一区二区三区 | 国产手机视频精品 | 中文字幕在线字幕中文 | 精品亚洲免a | 日本最新中文字幕 | 91久久精品一区二区二区 | 亚洲精品在线视频播放 | 亚洲成a人片在线观看网站口工 | av青草| 日韩成人中文字幕 | 成年人黄色免费视频 | 亚洲国产精品一区二区久久,亚洲午夜 | 91精品国产综合久久福利 | 国产精品久久久久久久99 | 久久国产精品久久w女人spa | 色婷婷狠狠 | 久久久精品国产免费观看同学 | 日韩在线国产精品 | 在线 国产一区 | 日本久久久亚洲精品 | 成人久久久电影 | 香蕉视频在线看 | 久久99热这里只有精品国产 | 天天爱天天操 | 色综合五月| 国产午夜精品免费一区二区三区视频 | 欧美国产精品一区二区 | av大片免费看| 国产精品人人做人人爽人人添 | 久久成人精品视频 | 日韩综合视频在线观看 | 久草在线精品观看 | 麻豆精品传媒视频 | 日韩午夜小视频 | 91私密保健| 西西人体www444 | 欧美日韩视频精品 | 在线观看成人毛片 | 一区二区日韩av | 欧美日韩国产网站 | 超碰人人91| 国产精品大片免费观看 | 久久精品99北条麻妃 | 国产美女免费 | 欧美精品一区二区三区一线天视频 | 97视频免费观看 | 一级成人免费视频 | 免费 在线 中文 日本 | 99久久超碰中文字幕伊人 | 色综合人人 | 人人爽久久涩噜噜噜网站 | 久久精品综合视频 | 三级av在线 | www黄免费 | 中文字幕国语官网在线视频 | 国产在线精品二区 | 丝袜美腿在线视频 | 午夜性色 | 国产精品久久久久毛片大屁完整版 | 国产成人精品亚洲日本在线观看 | 91视频首页 | 久久婷婷一区二区三区 | 欧美亚洲一区二区在线 | 91精品视频播放 | 国产在线高清精品 | 国产成人亚洲在线观看 | 五月天久久精品 | 日本在线视频一区二区三区 | 久久96国产精品久久99软件 | 久久久www| 五月天丁香视频 | 日日日天天天 | 91资源在线视频 | 国产免费三级在线观看 | 五月婷婷导航 | 亚洲成人家庭影院 | 日本久久久久 | 国产小视频在线观看免费 | 免费在线播放视频 | 精品国产视频一区 | 天天干,夜夜操 | 久久这里只有精品久久 | 在线观看一二三区 | 五月婷婷色| 免费99精品国产自在在线 | 黄网站免费大全入口 | 日韩av看片 | 国产又粗又长又硬免费视频 | 亚洲精品视频国产 | 日韩av一区二区在线 | 成人免费精品 | 成人午夜精品久久久久久久3d | 麻豆成人网 | 四虎最新域名 | 9992tv成人免费看片 | 亚洲午夜精品一区 | 2019中文最近的2019中文在线 | www色com | 超碰在线个人 | 一级久久久| 九九激情视频 | 久久精品一区二区三 | 在线国产99 | 日韩欧美在线视频一区二区 | 日本激情中文字幕 | 在线91观看| 国产91精品看黄网站在线观看动漫 | 欧美一级久久久久 | 国产精品久久久久久超碰 | 亚洲精品美女久久 | 99久免费精品视频在线观看 | 2017狠狠干 | 亚洲日本精品视频 | 亚洲经典在线 | 国产日女人 | 超碰在线日本 | 亚洲欧洲成人精品av97 | 久久再线视频 | 久日视频 | 日本3级在线观看 | 久香蕉| 欧美日韩在线视频一区二区 | 久久黄色小说 | 国产精品12345 | 国产精品视频你懂的 | 国产黄色片在线 | 亚欧日韩成人h片 | 国产一级在线视频 | 亚洲一区二区三区在线看 | 久久,天天综合 | 国产一级高清视频 | 久久夜夜操 | 久久蜜臀一区二区三区av | 国产一区在线免费观看 | 麻豆精品视频在线观看免费 | 亚洲精品视频免费在线 | 国产精品一区在线观看 | 99热官网| 五月婷婷婷婷婷 | 国产成人精品综合久久久 | 五月天婷婷在线播放 | 久久久精品欧美 | 免费看片成人 | 欧美一级性视频 | a特级毛片 | 久久这里只有精品首页 | 麻豆国产视频 | 亚洲干| 久久精品福利视频 | 久久久久久久久久久国产精品 | 天天操偷偷干 | 91插插插免费视频 | 欧美日韩aa | 久久精品久久精品久久 | 色av资源网 | 久久综合狠狠综合久久激情 | 一级黄色片在线免费观看 | 天天干夜夜夜操天 | 91成人网在线观看 | 欧美色综合| 欧美小视频在线 | 国产免费久久精品 | 超碰在线最新网址 | 亚洲九九九在线观看 | 日韩精品一区二区三区高清免费 | 国产女人免费看a级丨片 | 国产一区在线免费观看 | 国产成人一区二区精品非洲 | 亚洲成人网在线 | 91最新国产 | 日韩高清国产精品 | 国产精品久久精品国产 | 99草视频| 爱爱一区| 高清精品在线 | 高清av免费看 | 国产精品四虎 | 欧美性猛片 | 久久综合狠狠综合久久综合88 | www91在线观看| 久久免费视频在线观看30 | 天天舔天天搞 | 国产日韩欧美视频在线观看 | 在线观看日本韩国电影 | 国产视频精品免费播放 | 久久免费国产精品 | 亚洲国产一区在线观看 | 91成年人在线观看 | 免费电影一区二区三区 | 成人av中文字幕在线观看 | 中文字幕亚洲综合久久五月天色无吗'' | 97电院网手机版 | 九色精品免费永久在线 | 二区三区中文字幕 | 成人黄色毛片视频 | 国产在线精品一区 | 精品毛片在线 | 欧美另类人妖 | 日韩精品久久久久久久电影竹菊 | www国产亚洲精品久久麻豆 | 操久久免费视频 | 九九精品久久 | 日本一区二区高清不卡 | 亚洲一级国产 | 最近最新中文字幕视频 | 超碰在线观看99 | 国产视频精品免费播放 | 国产精品美女久久久久久久网站 | 色婷婷亚洲 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 国产精品网红直播 | 人交video另类hd | 久久国产一区二区 | 91成人精品一区在线播放69 | 在线播放一区二区三区 | 最近中文字幕mv免费高清在线 | 久久人人97超碰精品888 | 国产激情电影综合在线看 | 国产aa精品 | 欧美国产在线看 | 中文字幕精品视频 | 亚洲国产精品va在线 | 精品在线二区 | 亚洲激情精品 | 亚洲精品电影在线 | 国产韩国日本高清视频 | 欧美了一区在线观看 | 色国产精品 | 国产一区二区精品91 | 日韩素人在线观看 | 久久久.com | 精品国产乱码久久久久久1区2匹 | 成人av影视观看 | 999免费视频 | 免费网站黄 | 精品久久久久久久久久国产 | 特级毛片在线观看 | 久久激情电影 | 国产精品免费在线播放 | 日女人免费视频 | 九九热精品在线 | 丁香九月激情 | av综合站 | 国产成人精品综合 | 视频一区在线免费观看 | 精品福利视频在线 | 成人免费毛片aaaaaa片 | av观看久久久 | a极黄色片| 成年人免费av网站 | 在线观看成人福利 | 国产精品大片免费观看 | 日韩精品偷拍 | 欧美日韩国产在线一区 | 国产黄色大片免费看 | 日韩动漫免费观看高清完整版在线观看 | 国产精品乱码久久久久 | 一区在线观看 | 国产在线精品区 | 精品国产免费久久 | 91久久国产露脸精品国产闺蜜 | 天堂av在线中文在线 | 黄色大片av | 日韩免费播放 | 成人va天堂 | 五月婷婷六月丁香在线观看 | 欧美一级片免费在线观看 | 国产精品视频地址 | 免费福利影院 | 欧美日韩大片在线观看 | 免费观看丰满少妇做爰 | 成年人视频在线免费观看 | 亚洲综合欧美日韩狠狠色 | 一级久久精品 | mm1313亚洲精品国产 | 国产日韩欧美在线看 | 久久久久久久久久国产精品 | 五月婷婷丁香激情 | 亚洲成人午夜在线 | 国产福利av | 99免费看片 | 免费高清在线观看成人 | 成人午夜电影网站 | av成人免费 | 国产色爽 | 欧美日韩免费在线观看视频 | 蜜臀av性久久久久av蜜臀妖精 | 97电影手机 | 在线观av | 日韩精品欧美视频 | av一级二级| 操操操综合 | 在线观看国产亚洲 | 玖玖视频国产 | 欧美日本不卡高清 | 欧美视频日韩视频 | 欧美精品久久久久久久久老牛影院 | 国产精品第一视频 | 日女人免费视频 | 天天综合网天天 | 亚洲五月婷婷 | 天天操夜夜爱 | 高清免费在线视频 | 在线观看国产高清视频 | 久久丁香网 | 波多野结衣小视频 | 成年人免费电影在线观看 | 中文字幕欧美日韩va免费视频 | 五月天天色 | 东方av在线免费观看 | 一区二区激情视频 | 免费又黄又爽视频 | 日韩精品一区二区久久 | 日日爱999| av在线网站大全 | 狠狠色噜噜狠狠狠合久 | 在线亚洲精品 | 久久一区二区免费视频 | 九九视频在线播放 | 丁香花中文在线免费观看 | 婷婷六月网 | 欧美一二区视频 | 天天鲁一鲁摸一摸爽一爽 | 色综合五月 | 久久9视频| 国产原厂视频在线观看 | 奇米网777| 日韩欧美国产视频 | 亚洲欧美婷婷六月色综合 | 亚洲精品免费在线视频 | 人人爽人人看 | 日韩精品免费一区二区三区 | 最近中文字幕免费观看 | 成人午夜久久 | 麻豆久久一区二区 | 黄色av免费 | 国产日韩中文在线 | 成人黄色一级视频 | 国产亚洲免费观看 | 日韩aⅴ视频 | 欧美男同网站 | 久久综合影视 | 久久亚洲日本 | 99热精品在线 | 在线黄色国产电影 | 亚洲精品tv久久久久久久久久 | 久久精品一区二区三区四区 | 天天干天天玩天天操 | 中文字幕观看视频 | 91av在线免费视频 | 天天射天 | 色黄久久久久久 | 久久久免费看视频 | 亚洲 欧美 另类人妖 | 4438全国亚洲精品观看视频 | 天天做天天爱天天爽综合网 | 国产91精品高清一区二区三区 | 中文字幕色站 | 深夜激情影院 | av天天干 | 少妇性xxx | 久久这里只有精品首页 | 超碰公开在线 | 成人a免费看 | 天堂激情网| 久亚洲 | 四虎最新域名 | 国产精品网在线观看 | 在线看中文字幕 | 亚洲爽爽网 | 97av视频| 五月婷婷色综合 | 色综合a| 久久亚洲专区 | 亚洲涩涩色 | 在线观看小视频 | 观看免费av| 一本一道波多野毛片中文在线 | 免费观看av网站 | 97精产国品一二三产区在线 | 91| 精品嫩模福利一区二区蜜臀 | 久久久精品欧美 | 亚洲精品免费观看 | 在线日韩三级 | 99成人在线视频 | 欧美性极品xxxx做受 | 国产成人一区二区三区在线观看 | 国产在线观看xxx | 少妇bbw搡bbbb搡bbb | 夜夜干夜夜 | 久久天天躁夜夜躁狠狠躁2022 | 亚洲国产中文字幕在线视频综合 | 美女免费黄视频网站 | 久久免视频 | 久草在线免费看视频 | 黄色小网站在线 | 日韩午夜电影网 | 五月婷婷在线视频观看 | 7799av| 精品1区二区| 日韩av视屏在线观看 | 在线中文字母电影观看 | 久久久久免费精品国产 | 97色婷婷成人综合在线观看 | 91精品国产自产在线观看 | 欧美激情精品久久久久久免费印度 | 国产经典三级 | 国产四虎在线 | 亚洲国产精品一区二区尤物区 | 亚洲成av人影片在线观看 | 91香蕉视频720p | 久久免费美女视频 | 国产99久久精品一区二区永久免费 | 天天射网| 免费看国产视频 | 日韩欧美精品一区 | 国产成人专区 | 嫩嫩影院理论片 | 美女网站视频免费黄 | 成人小视频在线观看免费 | 精品久久视频 | 六月天色婷婷 | 日韩久久精品一区二区三区 | 五月天精品视频 | 免费看污的网站 | 欧美污在线观看 | 超碰在线观看av | 中文字幕在线观看亚洲 | 超碰在线97观看 | 久久久久久99精品 | 欧美日韩成人 | 欧美日韩大片在线观看 | 国产91在线看 | 一级成人免费视频 | www.天天干 | 国产高清在线永久 | 一本一本久久a久久精品综合 | 免费在线成人av电影 | 欧美性春潮 | 国产日本亚洲高清 | 九九九免费视频 | 又大又硬又黄又爽视频在线观看 | www天天操| 97国产情侣爱久久免费观看 | 玖玖玖在线观看 | 中文成人字幕 | 17videosex性欧美 | 久久艹在线观看 | 久久精品亚洲国产 | 国产在线p | 狠狠躁夜夜av | 日韩黄色中文字幕 | 免费裸体视频网 | 在线观看黄色的网站 | 中文字幕在线观看你懂的 | 在线a视频免费观看 | 毛片网站免费 | 亚洲国产成人高清精品 | 免费高清在线观看电视网站 | 国产在线播放观看 | 日日夜夜网站 | 日本黄色免费在线观看 | 91在线视频免费播放 | 99精品免费久久久久久久久 | 九九在线国产视频 | 在线观看国产永久免费视频 | 91精品一 | 日本狠狠干 | 国产 日韩 在线 亚洲 字幕 中文 | 高清av免费看 | 丁香花在线观看免费完整版视频 | 少妇bbw揉bbb欧美 | 一级片视频免费观看 | 日韩电影中文,亚洲精品乱码 | 成人av在线亚洲 | 精品久久精品久久 | 麻豆传媒视频观看 | 久久久福利影院 | 国产自产高清不卡 | 国产91亚洲精品 | 夜色资源站国产www在线视频 | 丁香视频| 久草在线视频网 | 三级av免费观看 | 国产精品久久电影观看 | av电影中文字幕在线观看 | 日韩在线视频网 | 夜夜夜| 中文字幕在线看视频国产中文版 | 日韩精品一区电影 | 九九亚洲视频 | 日韩精品免费一区二区在线观看 | 在线免费试看 | 色999在线 | 成人黄在线观看 | 不卡国产在线 | 91喷水| 在线观看免费中文字幕 | 一区二区三区四区五区六区 | 69绿帽绿奴3pvideos | 成人久久18免费网站麻豆 | 人人射人人射 | 国产精品 中文字幕 亚洲 欧美 | www日韩欧美|