SpringBoot整合ES多個(gè)精確值查詢 terms功能實(shí)現(xiàn)
ElasticSearch - SpringBoot整合ES:多個(gè)精確值查詢 terms
01. ElasticSearch terms 查詢支持的數(shù)據(jù)類型
在Elasticsearch中,terms查詢支持多種數(shù)據(jù)類型,包括:
字符串類型:可以將多個(gè)字符串值作為數(shù)組傳遞給terms查詢,以匹配包含任何一個(gè)指定字符串值的文檔。
數(shù)值類型:可以將多個(gè)數(shù)值作為數(shù)組傳遞給terms查詢,以匹配包含任何一個(gè)指定數(shù)值的文檔。
日期類型:可以將多個(gè)日期值作為數(shù)組傳遞給terms查詢,以匹配包含任何一個(gè)指定日期值的文檔。
布爾類型:可以將多個(gè)布爾值作為數(shù)組傳遞給terms查詢,以匹配包含任何一個(gè)指定布爾值的文檔。
復(fù)雜數(shù)據(jù)類型如數(shù)組類型,對(duì)象類型也可以支持,具體可以參考term查詢,term查詢支持的數(shù)據(jù)類型,terms查詢就會(huì)支持。區(qū)別在于 term查詢用于匹配一個(gè)字段中包含指定值的文檔,terms查詢用于匹配一個(gè)字段中包含指定值之一的文檔。
02. ElasticSearch term和 terms 查詢的區(qū)別
在Elasticsearch中,term和terms查詢都用于匹配一個(gè)字段中包含指定值的文檔,但它們之間有一些區(qū)別。
term查詢用于匹配包含完全相同值的文檔,而無法匹配包含部分匹配值的文檔。例如,以下查詢將返回包含"red"顏色的文檔:
{
"query": {
"term": {
"color": "red"
}
}
}但是,如果要查詢包含"red"或"blue"顏色的文檔,應(yīng)該使用terms查詢,而不是term查詢。例如,以下查詢將返回包含"red"或"blue"顏色中任何一個(gè)的文檔:
{
"query": {
"terms": {
"color": ["red", "blue"]
}
}
}terms查詢可以將多個(gè)值作為數(shù)組傳遞,以匹配包含任何一個(gè)指定值的文檔,而term查詢只能匹配包含單個(gè)指定值的文檔。因此,如果要匹配包含多個(gè)值的文檔,應(yīng)該使用terms查詢,而如果要匹配包含單個(gè)值的文檔,應(yīng)該使用term查詢。
03. ElasticSearch terms 查詢數(shù)值類型數(shù)據(jù)
一定要了解 term 和 terms 是包含操作,而非等值操作。 如何理解這句話呢?
在Elasticsearch中,term查詢用于匹配一個(gè)字段中包含指定值的文檔,terms查詢用于匹配一個(gè)字段中包含指定值之一的文檔??梢詫⒍鄠€(gè)值作為數(shù)組傳遞給terms查詢,以匹配包含任何一個(gè)指定值的文檔。
① 索引文檔,構(gòu)造數(shù)據(jù):
PUT /my_index
{
"mappings": {
"properties": {
"price":{
"type": "integer"
}
}
}
}
PUT /my_index/_doc/1
{
"price":10
}
PUT /my_index/_doc/2
{
"price":20
}
PUT /my_index/_doc/3
{
"price":30
}② 查詢 price 包含 "10"或"20"的文檔,可以使用以下查詢:
GET /my_index/_search
{
"query": {
"terms": {
"price": [
"10",
"20"
]
}
}
}{
"took" : 11,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 2,
"relation" : "eq"
},
"max_score" : 1.0,
"hits" : [
{
"_index" : "my_index",
"_type" : "_doc",
"_id" : "1",
"_score" : 1.0,
"_source" : {
"price" : 10
}
},
{
"_index" : "my_index",
"_type" : "_doc",
"_id" : "2",
"_score" : 1.0,
"_source" : {
"price" : 20
}
}
]
}
}04. ElasticSearch terms 查詢字符串型數(shù)據(jù)
terms查詢用于匹配一個(gè)字段中包含指定值之一的文檔。
① 索引文檔,數(shù)據(jù)構(gòu)造:
PUT /my_index
{
"mappings": {
"properties": {
"tag":{
"type": "keyword"
}
}
}
}
PUT /my_index/_doc/1
{
"tag":"tag1"
}
PUT /my_index/_doc/2
{
"tag":"tag2"
}
PUT /my_index/_doc/3
{
"tag":"tag3"
}② 查詢 tag 字段包含 tag1 和 tag2 的文檔:
GET /my_index/_search
{
"query": {
"terms": {
"tag": [
"tag1",
"tag2"
]
}
}
}{
"took" : 5,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 2,
"relation" : "eq"
},
"max_score" : 1.0,
"hits" : [
{
"_index" : "my_index",
"_type" : "_doc",
"_id" : "1",
"_score" : 1.0,
"_source" : {
"tag" : "tag1"
}
},
{
"_index" : "my_index",
"_type" : "_doc",
"_id" : "2",
"_score" : 1.0,
"_source" : {
"tag" : "tag2"
}
}
]
}
}不要使用term 和terms 查詢文本類型的數(shù)據(jù)。因?yàn)闀?huì)分詞,查詢可能會(huì)出現(xiàn)意想不到的結(jié)果。
05. ElasticSearch terms 查詢?nèi)掌谛詳?shù)據(jù)
① 索引文檔,構(gòu)造數(shù)據(jù):
PUT /my_index
{
"mappings": {
"properties": {
"createTime":{
"type": "date",
"format": "yyyy-MM-dd HH:mm:ss"
}
}
}
}
PUT /my_index/_doc/1
{
"createTime":"2023-03-29 10:30:11"
}
PUT /my_index/_doc/2
{
"createTime":"2023-03-29 10:35:11"
}
PUT /my_index/_doc/3
{
"createTime":"2023-03-29 10:38:11"
}② 查詢 createTime 字段包含 “2023-03-29 10:30:11” 或 “2023-03-29 10:38:11” 的文檔:
{
"took" : 672,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 2,
"relation" : "eq"
},
"max_score" : 1.0,
"hits" : [
{
"_index" : "my_index",
"_type" : "_doc",
"_id" : "1",
"_score" : 1.0,
"_source" : {
"createTime" : "2023-03-29 10:30:11"
}
},
{
"_index" : "my_index",
"_type" : "_doc",
"_id" : "3",
"_score" : 1.0,
"_source" : {
"createTime" : "2023-03-29 10:38:11"
}
}
]
}
}06. ElasticSearch terms 查詢布爾型數(shù)據(jù)
① 索引文檔,構(gòu)造數(shù)據(jù):
PUT /my_index
{
"mappings": {
"properties": {
"flag":{
"type": "boolean"
}
}
}
}
PUT /my_index/_doc/1
{
"flag":true
}
PUT /my_index/_doc/2
{
"flag":true
}
PUT /my_index/_doc/3
{
"flag":false
}② 查詢 flag 字段包含 true 或 false 的文檔:
GET /my_index/_search
{
"query": {
"terms": {
"flag": [
"true",
"false"
]
}
}
}{
"took" : 30,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 3,
"relation" : "eq"
},
"max_score" : 1.0,
"hits" : [
{
"_index" : "my_index",
"_type" : "_doc",
"_id" : "1",
"_score" : 1.0,
"_source" : {
"flag" : true
}
},
{
"_index" : "my_index",
"_type" : "_doc",
"_id" : "2",
"_score" : 1.0,
"_source" : {
"flag" : true
}
},
{
"_index" : "my_index",
"_type" : "_doc",
"_id" : "3",
"_score" : 1.0,
"_source" : {
"flag" : false
}
}
]
}
}07. ElasticSearch terms 查詢數(shù)組類型數(shù)據(jù)
terms查詢可以用于匹配一個(gè)字段中包含指定值之一的文檔。對(duì)于數(shù)組類型的字段,可以將多個(gè)值作為數(shù)組傳遞給terms查詢,以匹配包含任何一個(gè)指定值的文檔。
① 索引文檔,構(gòu)造數(shù)據(jù):
PUT /my_index
{
"mappings": {
"properties": {
"tags":{
"type": "keyword"
}
}
}
}
PUT /my_index/_doc/1
{
"tags":["tag1"]
}
PUT /my_index/_doc/2
{
"tags":["tag2"]
}
PUT /my_index/_doc/3
{
"tags":["tag1","tag2"]
}
PUT /my_index/_doc/4
{
"tags":["tag1","tag2","tag3"]
}② 要查詢 tags 字段包含"tag1"或"tag2"的文檔,可以使用以下查詢:
GET /my_index/_search
{
"query": {
"terms": {
"tags": [
"tag1",
"tag2"
]
}
}
}{
"took" : 4,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 4,
"relation" : "eq"
},
"max_score" : 1.0,
"hits" : [
{
"_index" : "my_index",
"_type" : "_doc",
"_id" : "1",
"_score" : 1.0,
"_source" : {
"tags" : [
"tag1"
]
}
},
{
"_index" : "my_index",
"_type" : "_doc",
"_id" : "2",
"_score" : 1.0,
"_source" : {
"tags" : [
"tag2"
]
}
},
{
"_index" : "my_index",
"_type" : "_doc",
"_id" : "3",
"_score" : 1.0,
"_source" : {
"tags" : [
"tag1",
"tag2"
]
}
},
{
"_index" : "my_index",
"_type" : "_doc",
"_id" : "4",
"_score" : 1.0,
"_source" : {
"tags" : [
"tag1",
"tag2",
"tag3"
]
}
}
]
}
}08. ElasticSearch terms 查詢對(duì)象型數(shù)據(jù)
① 索引文檔,構(gòu)造數(shù)據(jù):
PUT /my_index
{
"mappings": {
"properties": {
"person": {
"type": "object",
"properties": {
"name": {
"type": "keyword"
},
"age": {
"type": "integer"
},
"address": {
"type": "keyword"
}
}
}
}
}
}
PUT /my_index/_doc/1
{
"person": {
"name": "John",
"age": 30,
"address": "123 Main St"
}
}
PUT /my_index/_doc/2
{
"person": {
"name": "Alex",
"age": 20,
"address": "123 Main St"
}
}
PUT /my_index/_doc/3
{
"person": {
"name": "Smith",
"age": 10,
"address": "123 Main St"
}
}② 查詢 person.name 字段包含 Alex 或者 Smith 的文檔:
{
"took" : 2,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 2,
"relation" : "eq"
},
"max_score" : 1.0,
"hits" : [
{
"_index" : "my_index",
"_type" : "_doc",
"_id" : "2",
"_score" : 1.0,
"_source" : {
"person" : {
"name" : "Alex",
"age" : 20,
"address" : "123 Main St"
}
}
},
{
"_index" : "my_index",
"_type" : "_doc",
"_id" : "3",
"_score" : 1.0,
"_source" : {
"person" : {
"name" : "Smith",
"age" : 10,
"address" : "123 Main St"
}
}
}
]
}
}09. SpringBoot 整合ES實(shí)現(xiàn)terms查詢
GET /my_index/_search
{
"query": {
"terms": {
"price": [
"10",
"20"
]
}
}
}@Slf4j
@Service
public class ElasticSearchImpl {
@Autowired
private RestHighLevelClient restHighLevelClient;
public void searchUser() throws IOException {
SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
// terms查詢
List<Integer> prices = Arrays.asList(10,20);
// 查詢所有price字段包含10或者20的文檔
TermsQueryBuilder termsQueryBuilder = new TermsQueryBuilder("price",prices);
searchSourceBuilder.query(termsQueryBuilder);
SearchRequest searchRequest = new SearchRequest(new String[]{"my_index"},searchSourceBuilder);
SearchResponse searchResponse = restHighLevelClient.search(searchRequest, RequestOptions.DEFAULT);
System.out.println(searchResponse);
}
}10. SpringBoot 整合ES實(shí)現(xiàn)terms查詢
GET /my_index/_search
{
"query": {
"terms": {
"tags": ["tag1","tag2"]
}
}
}@Slf4j
@Service
public class ElasticSearchImpl {
@Autowired
private RestHighLevelClient restHighLevelClient;
public void searchUser() throws IOException {
SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
// terms查詢
List<String> tags = Arrays.asList("tag1","tag2");
// 查詢所有tags字段包含tag1或者tag2的文檔
TermsQueryBuilder termsQueryBuilder = new TermsQueryBuilder("tags",tags);
searchSourceBuilder.query(termsQueryBuilder);
SearchRequest searchRequest = new SearchRequest(new String[]{"my_index"},searchSourceBuilder);
SearchResponse searchResponse = restHighLevelClient.search(searchRequest, RequestOptions.DEFAULT);
System.out.println(searchResponse);
}
}到此這篇關(guān)于SpringBoot整合ES多個(gè)精確值查詢 terms功能實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)SpringBoot整合ES查詢內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Sentinel熱門詞匯限流的實(shí)現(xiàn)詳解
這篇文章主要介紹了使用Sentinel對(duì)熱門詞匯進(jìn)行限流的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07
淺談spring中的default-lazy-init參數(shù)和lazy-init
下面小編就為大家?guī)硪黄獪\談spring中的default-lazy-init參數(shù)和lazy-init。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-04-04
如何解決Project SDK is not defined問題
這篇文章主要介紹了如何解決Project SDK is not defined問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09
SpringBoot集成Swagger構(gòu)建api文檔的操作
這篇文章主要介紹了SpringBoot集成Swagger構(gòu)建api文檔的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-12-12
RocketMQ之Consumer整體介紹啟動(dòng)源碼分析
這篇文章主要為大家介紹了RocketMQ源碼分析之Consumer整體介紹啟動(dòng)分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05

