ElasticSearch6.0 Java API 使用 排序,分组 ,创建索引,添加索引数据,打分等(一)

ElasticSearch6.0  Java API  使用     排序,分组 ,创建索引,添加索引数据,打分等

如果此文章对你有帮助,请关注一下哦

1.1 搭建maven 工程  创建web工程

  1 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  2   xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
  3   <modelVersion>4.0.0</modelVersion>
  4   <groupId>com.elastic</groupId>
  5   <artifactId>search-service</artifactId>
  6   <packaging>war</packaging>
  7   <version>1.0-SNAPSHOT</version>
  8   <name>search-service Maven Webapp</name>
  9   <url>http://maven.apache.org</url>
 10   <properties>
 11     <junit.version>4.5</junit.version>
 12     <spring.version>4.2.4.RELEASE</spring.version>
 13     <mybatis.version>3.2.8</mybatis.version>
 14     <mybatis.spring.version>1.2.2</mybatis.spring.version>
 15     <mybatis.paginator.version>1.2.15</mybatis.paginator.version>
 16     <mysql.version>5.1.32</mysql.version>
 17     <slf4j.version>1.6.4</slf4j.version>
 18     <jackson.version>2.4.2</jackson.version>
 19     <druid.version>1.0.9</druid.version>
 20     <jstl.version>1.2</jstl.version>
 21     <servlet-api.version>2.5</servlet-api.version>
 22     <jsp-api.version>2.0</jsp-api.version>
 23     <joda-time.version>2.5</joda-time.version>
 24     <commons-lang3.version>3.3.2</commons-lang3.version>
 25     <commons-io.version>1.3.2</commons-io.version>
 26     <commons-net.version>3.3</commons-net.version>
 27     <jsqlparser.version>0.9.1</jsqlparser.version>
 28     <commons-fileupload.version>1.3.1</commons-fileupload.version>
 29     <jedis.version>2.7.2</jedis.version>
 30     <activemq.version>5.11.2</activemq.version>
 31     <quartz.version>2.2.2</quartz.version>
 32     <slf4j.version>1.7.21</slf4j.version>
 33     <log4j.version>1.2.12</log4j.version>
 34     <solr.version>6.1.0</solr.version>
 35     <fastjson.version>1.2.13</fastjson.version>
 36     <diamond.version>0.0.1-SNAPSHOT</diamond.version>
 37     <cors.filter>2.5</cors.filter>
 38     <java.property.utils>1.10</java.property.utils>
 39     <jackson.version>2.4.2</jackson.version>
 40   </properties>
 41   <dependencies>
 42     <dependency>
 43       <groupId>junit</groupId>
 44       <artifactId>junit</artifactId>
 45       <version>3.8.1</version>
 46       <scope>test</scope>
 47     </dependency>
 48     <dependency>
 49       <groupId>org.elasticsearch.client</groupId>
 50       <artifactId>transport</artifactId>
 51       <version>6.0.0</version>
 52     </dependency>
 53     <dependency>
 54       <groupId>org.slf4j</groupId>
 55       <artifactId>jcl-over-slf4j</artifactId>
 56       <version>1.7.21</version>
 57       <scope>runtime</scope>
 58     </dependency>
 59     <dependency>
 60       <groupId>org.slf4j</groupId>
 61       <artifactId>slf4j-api</artifactId>
 62       <version>1.7.21</version>
 63     </dependency>
 64     <!-- https://mvnrepository.com/artifact/org.slf4j/slf4j-log4j12 -->
 65     <dependency>
 66       <groupId>org.slf4j</groupId>
 67       <artifactId>slf4j-log4j12</artifactId>
 68       <scope>runtime</scope>
 69     </dependency>
 70     <!-- https://mvnrepository.com/artifact/log4j/log4j -->
 71     <dependency>
 72       <groupId>log4j</groupId>
 73       <artifactId>log4j</artifactId>
 74       <version>1.2.17</version>
 75     </dependency>
 76     <dependency>
 77       <groupId>commons-logging</groupId>
 78       <artifactId>commons-logging</artifactId>
 79       <version>1.2</version>
 80     </dependency>
 81     <dependency>
 82       <groupId>junit</groupId>
 83       <artifactId>junit</artifactId>
 84       <scope>test</scope>
 85     </dependency>
 86     <dependency>
 87       <groupId>javax.servlet</groupId>
 88       <artifactId>servlet-api</artifactId>
 89       <version>2.5</version>
 90       <scope>provided</scope>
 91     </dependency>
 92     <dependency>
 93       <groupId>com.alibaba</groupId>
 94       <artifactId>fastjson</artifactId>
 95     </dependency>
 96     <!-- spring dependencies -->
 97     <dependency>
 98       <groupId>org.springframework</groupId>
 99       <artifactId>spring-core</artifactId>
100       <version>${spring.version}</version>
101       <!--<exclusions>-->
102       <!--<exclusion>-->
103       <!--<groupId>commons-logging</groupId>-->
104       <!--<artifactId>commons-logging</artifactId>-->
105       <!--</exclusion>-->
106       <!--</exclusions>-->
107     </dependency>
108     <dependency>
109       <groupId>org.springframework</groupId>
110       <artifactId>spring-test</artifactId>
111       <version>${spring.version}</version>
112     </dependency>
113     <dependency>
114       <groupId>org.springframework</groupId>
115       <artifactId>spring-context</artifactId>
116       <version>${spring.version}</version>
117     </dependency>
118     <dependency>
119       <groupId>org.springframework</groupId>
120       <artifactId>spring-context-support</artifactId>
121       <version>${spring.version}</version>
122     </dependency>
123     <dependency>
124       <groupId>org.springframework</groupId>
125       <artifactId>spring-aop</artifactId>
126       <version>${spring.version}</version>
127     </dependency>
128     <dependency>
129       <groupId>org.springframework</groupId>
130       <artifactId>spring-aspects</artifactId>
131       <version>${spring.version}</version>
132     </dependency>
133     <dependency>
134       <groupId>org.springframework</groupId>
135       <artifactId>spring-tx</artifactId>
136       <version>${spring.version}</version>
137     </dependency>
138     <!-- https://mvnrepository.com/artifact/org.springframework/spring-jdbc -->
139     <dependency>
140       <groupId>org.springframework</groupId>
141       <artifactId>spring-jdbc</artifactId>
142       <version>${spring.version}</version>
143     </dependency>
144 
145     <dependency>
146       <groupId>org.springframework</groupId>
147       <artifactId>spring-webmvc</artifactId>
148       <version>${spring.version}</version>
149     </dependency>
150     <!-- mysql dependencies -->
151     <dependency>
152       <groupId>mysql</groupId>
153       <artifactId>mysql-connector-java</artifactId>
154       <version>5.1.32</version>
155     </dependency>
156     <!-- https://mvnrepository.com/artifact/com.thetransactioncompany/cors-filter -->
157     <dependency>
158       <groupId>com.thetransactioncompany</groupId>
159       <artifactId>cors-filter</artifactId>
160       <version>${cors.filter}</version>
161     </dependency>
162     <!-- https://mvnrepository.com/artifact/com.thetransactioncompany/java-property-utils -->
163     <dependency>
164       <groupId>com.thetransactioncompany</groupId>
165       <artifactId>java-property-utils</artifactId>
166       <version>${java.property.utils}</version>
167 
168     </dependency>
169     <dependency>
170       <groupId>com.alibaba</groupId>
171       <artifactId>fastjson</artifactId>
172       <version>${fastjson.version}</version>
173     </dependency>
174   </dependencies>
175   <build>
176     <finalName>search-service</finalName>
177   </build>
178 </project>

 

1.2 创建web项目

 

 

 

2.1  编写Java  elasticsearch 客户端连接公共类  (这里使用elasticsearch单机版)

 1 package com.elastic.common.conn;
 2 
 3 import org.elasticsearch.client.transport.TransportClient;
 4 import org.elasticsearch.common.settings.Settings;
 5 import org.elasticsearch.common.transport.TransportAddress;
 6 import org.elasticsearch.transport.client.PreBuiltTransportClient;
 7 import org.springframework.stereotype.Component;
 8 
 9 import java.net.InetAddress;
10 
11 /**
12  * Created by xiaotian on 2017/12/1.
13  */
14 @Component
15 public class EsClient {
16 
17     //private  EsClient client = new EsClient();
18     TransportClient client = null;
19     public  EsClient(){
20         try{
21             Settings settings = Settings.builder()
22                     .put("client.transport.sniff", true)
23                     .put("cluster.name", "elasticsearch").build();
24             client = new PreBuiltTransportClient(Settings.EMPTY)
25                     .addTransportAddress(new TransportAddress(InetAddress.getByName("eshost"), 9300));
26 
27         }catch (Exception ex){
28             client.close();
29         }finally {
30 
31         }
32     }
33     public  TransportClient getConnection(){
34 
35            if (client==null){
36                synchronized (EsClient.class){
37                    if (client==null){
38                        new EsClient();
39                    }
40                }
41            }
42            return  client;
43 
44     }
45 
46 }

 2.2  service层  接口设计 

1. IndexService
 1 package com.elastic.service.inter;
 2 
 3 /**
 4  * Created by xiaotian on 2017/12/1.
 5  */
 6 public interface IndexService {
 7 
 8    public void  index(String id);
 9 
10    public  void  get();
11    public  void  del(String id);
12    public  void  update(String id) throws  Exception;
13    public  void  multiGet(String ... ids) throws  Exception;
14    public  void  bulk(String ... ids) throws  Exception;
15    public  void  bulkProcesstor(String index,String type,String... ids) throws  Exception;
16 
17 }

 

2. SearchService

 1 package com.elastic.service.inter;
 2 
 3 /**
 4  * Created by xiaotian on 2017/12/2.
 5  */
 6 public interface SearchService {
 7     public void  search();
 8     public void  searchByCondition() throws Exception;
 9     public void  multiSearch();
10     public void aggsearch();
11     public void metricsAgg();
12 
13 }

3. service层 接口实现 

  IndexServiceImpl 

 

  1 package com.elastic.service.impl;
  2 
  3 import com.alibaba.fastjson.JSONObject;
  4 import com.elastic.common.conn.EsClient;
  5 import com.elastic.service.inter.IndexService;
  6 import org.elasticsearch.action.ActionListener;
  7 import org.elasticsearch.action.admin.indices.mapping.put.PutMappingRequest;
  8 import org.elasticsearch.action.admin.indices.mapping.put.PutMappingResponse;
  9 import org.elasticsearch.action.bulk.*;
 10 import org.elasticsearch.action.get.GetResponse;
 11 import org.elasticsearch.action.get.MultiGetItemResponse;
 12 import org.elasticsearch.action.get.MultiGetResponse;
 13 import org.elasticsearch.action.index.IndexRequest;
 14 import org.elasticsearch.action.index.IndexRequestBuilder;
 15 import org.elasticsearch.action.index.IndexResponse;
 16 import org.elasticsearch.client.Requests;
 17 import org.elasticsearch.common.document.DocumentField;
 18 import org.elasticsearch.common.unit.ByteSizeUnit;
 19 import org.elasticsearch.common.unit.ByteSizeValue;
 20 import org.elasticsearch.common.unit.TimeValue;
 21 import org.elasticsearch.common.xcontent.XContentBuilder;
 22 import org.elasticsearch.common.xcontent.XContentType;
 23 import org.elasticsearch.index.query.QueryBuilders;
 24 import org.elasticsearch.index.reindex.BulkByScrollResponse;
 25 import org.elasticsearch.index.reindex.DeleteByQueryAction;
 26 import org.elasticsearch.rest.RestStatus;
 27 import org.springframework.beans.factory.annotation.Autowired;
 28 import org.springframework.stereotype.Service;
 29 
 30 import java.io.IOException;
 31 import java.util.*;
 32 
 33 import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
 34 
 35 /**
 36  * Created by xiaotian on 2017/12/1.
 37  */
 38 @Service
 39 public class IndexServiceImpl implements IndexService {
 40 
 41     @Autowired
 42     private EsClient client;
 43 
 44     public void index(String id) {
 45 //        String json = "{" +
 46 //                "\"user\":\"kimchy\"," +
 47 //                "\"postDate\":\"2013-01-30\"," +
 48 //                "\"message\":\"trying out Elasticsearch\"" +
 49 //                "}";
 50         try {
 51 
 52 
 53         Map<String, Object> jsonMap = new HashMap<String, Object>();
 54         jsonMap.put("name","jim"+id);
 55         jsonMap.put("age",20+id);
 56         jsonMap.put("date",new Date());
 57         jsonMap.put("message","测试"+id);
 58         jsonMap.put("tel","1234567");
 59         //IndexResponse indexResponse = client.getConnection().prepareIndex("twitter", "tweet").setSource(JSONObject.toJSON(jsonMap), XContentType.JSON).get();
 60         IndexResponse indexResponse = client.getConnection().prepareIndex("xiaot", "test",id).setSource(jsonMap).get();
 61        // Index name
 62         String _index = indexResponse.getIndex();
 63         // Type name
 64         String _type = indexResponse.getType();
 65         // Document ID (generated or not)
 66         String _id = indexResponse.getId();
 67         // Version (if it's the first time you index this document, you will get: 1)
 68         long _version = indexResponse.getVersion();
 69         // status has stored current instance statement.
 70         RestStatus status = indexResponse.status();
 71         System.out.println(_index+"_"+_type+"_"+_id+"_"+_version+"_"+status);
 72         }catch (Exception ex){
 73             ex.printStackTrace();
 74         }
 75 
 76     }
 77 
 78     public void get() {
 79         GetResponse response = client.getConnection().prepareGet("twitter", "tweet", "94pKEWABJOgzR6sJVCCV").get();
 80         Map<String, DocumentField> fields = response.getFields();
 81         System.out.println("map:"+fields);
 82         String index = response.getIndex();
 83         Map<String, Object> source = response.getSource();
 84         String id = response.getId();
 85         System.out.println(source);
 86 
 87     }
 88 
 89     public void del(String id) {
 90         DeleteByQueryAction.INSTANCE.newRequestBuilder(client.getConnection())
 91                 .filter(QueryBuilders.matchQuery("_id",id))
 92                 .source("twitter")
 93                 .execute(new ActionListener<BulkByScrollResponse>() {
 94                     public void onResponse(BulkByScrollResponse response) {
 95                         long deleted = response.getDeleted();
 96                         System.out.println("delete"+deleted);
 97                     }
 98 
 99                     public void onFailure(Exception e) {
100 
101                     }
102                 });
103     }
104 
105     public void update(String id)  throws  Exception{
106         client.getConnection().prepareUpdate("twitter","tweet",id)
107                 .setDoc(jsonBuilder()
108                         .startObject()
109                         .field("name", "tom")
110                         .endObject()).get();
111     }
112 
113     public void multiGet(String... ids) throws Exception {
114         MultiGetResponse multiGetResponse = client.getConnection().prepareMultiGet()
115                 .add("twitter", "tweet", ids[0])
116                 .add("twitter", "tweet", ids[1], ids[2], ids[3])
117                 .get();
118         for (MultiGetItemResponse multiGetItemResponse : multiGetResponse) {
119             GetResponse response = multiGetItemResponse.getResponse();
120             if (response.isExists()){
121                 System.out.println(response.getSourceAsString());
122             }
123         }
124     }
125 
126     public void bulk(String... ids) throws Exception {
127         BulkRequestBuilder prepareBulk = client.getConnection().prepareBulk();
128         for (String id : ids) {
129             prepareBulk.add(client.getConnection().prepareIndex("twitter","tweet",id)
130             .setSource(jsonBuilder().startObject().field("name","肖添"+id).endObject()));
131 
132         }
133         BulkResponse responses = prepareBulk.get();
134         System.out.println(responses.hasFailures());
135         for (BulkItemResponse response : responses) {
136             System.out.println(response.getResponse().getId() + "," + response.getResponse().getIndex() + "," + response.getResponse().getResult());
137         }
138 
139     }
140 
141     public void bulkProcesstor(String index,String type,String... ids) throws Exception {
142         try {
143 
144            //IndexResponse indexResponse = client.getConnection().prepareIndex(index, type).setSource(getMapping()).get();
145            IndexResponse indexResponse = client.getConnection().prepareIndex(index, type).setSource().get();
146 
147             PutMappingRequest mappingRequest = Requests.putMappingRequest(index).type(type).source(getMapping());
148             PutMappingResponse putMappingResponse = client.getConnection().admin().indices().putMapping(mappingRequest).actionGet();
149             //client.getConnection().prepareIndex("temp1","test").
150             BulkProcessor bulkProcessor = BulkProcessor.builder(client.getConnection(), new BulkProcessor.Listener() {
151                 public void beforeBulk(long executionId, BulkRequest bulkRequest) {
152                     System.out.println("beforeBulk:" + executionId + "," + bulkRequest.getDescription() + "," + bulkRequest.numberOfActions());
153                 }
154 
155                 public void afterBulk(long executionId, BulkRequest bulkRequest, BulkResponse bulkResponse) {
156                     System.out.println("afterBulk:" + executionId + "," + bulkRequest.getDescription() + "," + bulkRequest.numberOfActions());
157                     System.out.println("afterBulk:" + executionId + "," + bulkResponse.getItems() + "," + bulkResponse.getTook());
158                 }
159 
160                 public void afterBulk(long executionId, BulkRequest bulkRequest, Throwable throwable) {
161                     System.out.println("afterBulk:" + executionId + "," + bulkRequest.getParentTask() + "," + bulkRequest.getDescription() + "," + throwable);
162                 }
163             })
164                     .setBulkActions(10)
165                     .setBulkSize(new ByteSizeValue(5, ByteSizeUnit.MB))
166                     .setConcurrentRequests(1)
167                     .setFlushInterval(TimeValue.timeValueMillis(1))
168                     .setBackoffPolicy(BackoffPolicy.exponentialBackoff(TimeValue.timeValueMillis(100), 3)).build();
169 
170             for (String id : ids) {
171                 Map<String, Object> jsonMap = new HashMap<String, Object>();
172                 jsonMap.put("name","中华人民共和国"+id);
173                 jsonMap.put("age",30+Integer.parseInt(id));
174                 jsonMap.put("date",new Date());
175                 jsonMap.put("message","程序设计"+id);
176                 jsonMap.put("tel","18612855433");
177                 jsonMap.put("attr_name",new String[]{"品牌_sku_attr"+id,"商品类别_sku_attr"+id,"面料_sku_attr"+id});
178                 jsonMap.put("create_date",new Date());
179                 bulkProcessor.add(new IndexRequest(index,type,id).source(jsonMap));
180 
181             }
182             bulkProcessor.close();
183         } catch (Exception e) {
184             e.printStackTrace();
185             System.out.println(e);
186         }finally {
187 
188         }
189 
190     }
191 
192     private XContentBuilder getMapping() throws Exception{
193         XContentBuilder mapping = null;
194         try {
195 
196             mapping = jsonBuilder().startObject()//.startObject("_ttl").field("enabled",false).endObject()
197                                                    .startObject("properties").startObject("name").field("type","text").field("analyzer","ik_max_word")
198                                                    .field("search_analyzer","ik_max_word").endObject()
199                                                    .startObject("age").field("type","long").endObject()
200                                                    .startObject("date").field("type","date").endObject()
201                                                     .startObject("message").field("type","keyword").field("index","true").endObject()
202                                                     .startObject("tel").field("type","keyword").endObject()
203                                                     .startObject("attr_name").field("type","keyword").field("index","true").endObject()
204                          .endObject()
205                     .endObject();
206         } catch (IOException e) {
207             e.printStackTrace();
208         }
209 
210        return  mapping;
211     }
212 }

SearchServiceImpl

  1 package com.elastic.service.impl;
  2 
  3 import com.elastic.common.conn.EsClient;
  4 import com.elastic.service.inter.SearchService;
  5 import org.apache.lucene.index.Term;
  6 import org.elasticsearch.action.search.MultiSearchResponse;
  7 import org.elasticsearch.action.search.SearchRequestBuilder;
  8 import org.elasticsearch.action.search.SearchResponse;
  9 import org.elasticsearch.action.search.SearchType;
 10 import org.elasticsearch.common.lucene.search.function.CombineFunction;
 11 import org.elasticsearch.common.lucene.search.function.FieldValueFactorFunction;
 12 import org.elasticsearch.index.query.*;
 13 import org.elasticsearch.index.query.functionscore.*;
 14 import org.elasticsearch.join.aggregations.Children;
 15 import org.elasticsearch.script.Script;
 16 import org.elasticsearch.script.ScriptService;
 17 import org.elasticsearch.script.ScriptType;
 18 import org.elasticsearch.search.SearchHit;
 19 import org.elasticsearch.search.SearchHits;
 20 import org.elasticsearch.search.aggregations.*;
 21 import org.elasticsearch.search.aggregations.bucket.filter.FilterAggregationBuilder;
 22 import org.elasticsearch.search.aggregations.bucket.filter.FiltersAggregator;
 23 import org.elasticsearch.search.aggregations.bucket.filter.InternalFilter;
 24 import org.elasticsearch.search.aggregations.bucket.range.Range;
 25 import org.elasticsearch.search.aggregations.bucket.range.RangeAggregationBuilder;
 26 import org.elasticsearch.search.aggregations.bucket.range.RangeAggregator;
 27 import org.elasticsearch.search.aggregations.bucket.terms.Terms;
 28 import org.elasticsearch.search.aggregations.bucket.terms.TermsAggregationBuilder;
 29 import org.elasticsearch.search.aggregations.metrics.avg.Avg;
 30 import org.elasticsearch.search.aggregations.metrics.avg.AvgAggregationBuilder;
 31 import org.elasticsearch.search.aggregations.metrics.max.Max;
 32 import org.elasticsearch.search.aggregations.metrics.max.MaxAggregationBuilder;
 33 import org.elasticsearch.search.aggregations.metrics.min.Min;
 34 import org.elasticsearch.search.aggregations.metrics.min.MinAggregationBuilder;
 35 import org.elasticsearch.search.aggregations.metrics.stats.Stats;
 36 import org.elasticsearch.search.aggregations.metrics.stats.StatsAggregationBuilder;
 37 import org.elasticsearch.search.aggregations.metrics.stats.extended.ExtendedStats;
 38 import org.elasticsearch.search.aggregations.metrics.stats.extended.ExtendedStatsAggregationBuilder;
 39 import org.elasticsearch.search.aggregations.metrics.sum.Sum;
 40 import org.elasticsearch.search.aggregations.metrics.sum.SumAggregationBuilder;
 41 import org.elasticsearch.search.rescore.RescoreBuilder;
 42 import org.elasticsearch.search.sort.SortOrder;
 43 import org.slf4j.Logger;
 44 import org.springframework.beans.factory.annotation.Autowired;
 45 import org.springframework.stereotype.Service;
 46 
 47 import java.text.SimpleDateFormat;
 48 import java.util.HashMap;
 49 import java.util.List;
 50 import java.util.Map;
 51 
 52 import static org.elasticsearch.index.query.QueryBuilders.functionScoreQuery;
 53 
 54 /**
 55  * Created by xiaotian on 2017/12/2.
 56  */
 57 @Service
 58 public class SearchServiceImpl implements SearchService {
 59     @Autowired
 60     private EsClient client;
 61 
 62     private static final org.apache.log4j.Logger logger = org.apache.log4j.Logger.getLogger(SearchServiceImpl.class);
 63 
 64     public void search() {
 65         SearchResponse searchResponse = client.getConnection().prepareSearch("twitter")
 66                 .setTypes("tweet")
 67                 .setSearchType(SearchType.DFS_QUERY_THEN_FETCH)
 68                 .setQuery(QueryBuilders.matchQuery("name","三胖子"))
 69                 .setPostFilter(QueryBuilders.rangeQuery("age").from(19).to(400))
 70                 .setFrom(0).setSize(20).setExplain(true)
 71                 //.addAggregation(AggregationBuilder.CommonFields.FIELD.match(""))
 72                 .get();
 73 
 74         SearchHits hits = searchResponse.getHits();
 75         for (SearchHit hit : hits) {
 76             System.out.println(hit.getSourceAsMap());
 77         }
 78     }
 79 
 80     public void searchByCondition()  throws Exception{
 81 
 82 
 83         SearchRequestBuilder searchRequestBuilder = client.getConnection().prepareSearch("red89")
 84                 .setTypes("test");
 85 
 86 
 87         Map<String, Object> params = new HashMap<>();
 88         params.put("num1", 1);
 89         params.put("num2", 2);
 90 
 91         String inlineScript = "long age;if (doc['age'].value < 45)  age = doc['age'].value + 50; return age * params.num1;";
 92                // + "return (diff +num1+num2)";
 93         Script script = new Script(ScriptType.INLINE,"painless",inlineScript , params);
 94         ScriptScoreFunctionBuilder scriptScoreFunctionBuilder = ScoreFunctionBuilders.scriptFunction(script);
 95 
 96 
 97 
 98         //MatchQueryBuilder matchQueryBuilder = QueryBuilders.matchQuery("name", "中华");
 99 
100         searchRequestBuilder.setQuery(functionScoreQuery(QueryBuilders.matchQuery("name","中华").operator(Operator.AND),scriptScoreFunctionBuilder));
101        // searchRequestBuilder.setQuery(QueryBuilders.matchQuery("name","中华").operator(Operator.AND));
102         BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();
103         BoolQueryBuilder queryBuilder = QueryBuilders.boolQuery();
104         getFilterQuery("tel",new String[]{"18612855433"},"AND",queryBuilder);
105        // getFilterQuery("name",new String[]{"中华人民共和国"},"AND",queryBuilder);
106 
107 
108         //getFilterQuery("age",new String[]{"40"},"AND",queryBuilder);
109         //getFilterQuery("message",new String[]{"程序设计19"},"AND",queryBuilder);
110         boolQueryBuilder.must(queryBuilder);
111         //boolQueryBuilder.must();
112        // boolQueryBuilder.must(getRangeFilterQuery("age",new Integer[]{null,45}));
113         //new_score = old_score * log(1 + factor * number_of_votes)
114 
115        FieldValueFactorFunctionBuilder age = ScoreFunctionBuilders.fieldValueFactorFunction("age").modifier(FieldValueFactorFunction.Modifier.LN1P).factor(10);
116         FieldValueFactorFunctionBuilder age1 = ScoreFunctionBuilders.fieldValueFactorFunction("age").modifier(FieldValueFactorFunction.Modifier.LN1P).factor(4);
117         FunctionScoreQueryBuilder.FilterFunctionBuilder[] filterFunctionBuilders =
118                 new FunctionScoreQueryBuilder.FilterFunctionBuilder[]{new FunctionScoreQueryBuilder.FilterFunctionBuilder(age),new FunctionScoreQueryBuilder.FilterFunctionBuilder(age1)};
119         //FunctionScoreQueryBuilder scoreQueryBuilder = functionScoreQuery(boolQueryBuilder, filterFunctionBuilders).boostMode(CombineFunction.SUM);
120 
121        // FunctionScoreQueryBuilder functionScoreQueryBuilder = functionScoreQuery(boolQueryBuilder, scriptScoreFunctionBuilder);
122         searchRequestBuilder.setPostFilter(boolQueryBuilder);
123         searchRequestBuilder.setFrom(0);
124         searchRequestBuilder.setSize(20);
125         searchRequestBuilder.setExplain(true);
126 
127         TermsAggregationBuilder aggregationBuilder = AggregationBuilders.terms("agg").field("attr_name");//.subAggregation(AggregationBuilders.topHits("top").from(0).size(10)).size(100);
128         RangeAggregationBuilder rangeAggregationBuilder = AggregationBuilders.range("range").field("age").addRange(0, 30).addRange(30,50).addRange(50,100);
129 
130         aggregationBuilder.size(100);
131 
132         AggregationBuilder filter = AggregationBuilders.filter("agg", boolQueryBuilder)
133                 .subAggregation(aggregationBuilder);
134 
135         searchRequestBuilder.addAggregation(filter);
136         searchRequestBuilder.addAggregation(rangeAggregationBuilder);
137        // searchRequestBuilder.addAggregation(filter);
138         //searchRequestBuilder.addSort("age",SortOrder.DESC);
139 
140 
141 
142 
143 
144         //打分
145         //searchRequestBuilder.addRescorer(RescoreBuilder.queryRescorer(QueryBuilders.functionScoreQuery(ScoreFunctionBuilders.fieldValueFactorFunction("age"))));
146 
147         SearchResponse searchResponse1 = searchRequestBuilder.get();
148 
149 
150         System.out.println("param:"+searchRequestBuilder.toString());
151 
152 
153 
154         System.out.println("aaaa"+searchResponse1.getAggregations().getAsMap());
155 
156 
157         InternalFilter aggFilter = searchResponse1.getAggregations().get("agg");
158         System.out.println(aggFilter.toString());
159         Terms agg = aggFilter.getAggregations().get("agg");
160 
161         agg.getBuckets().forEach(bucket ->{
162             System.out.println(bucket.getKey()+":"+bucket.getDocCount());
163         } );
164         System.out.println("--------------------------------");
165         Range range = searchResponse1.getAggregations().get("range");
166 
167         range.getBuckets().forEach(bucket ->{
168             //System.out.println(bucket.getKey()+":"+bucket.getDocCount());
169             //logger.info("key [{}], from [{}], to [{}], doc_count [{}]", bucket.getKey(), bucket.getFrom(),bucket.getTo(),bucket.getDocCount());
170             System.out.println(String.format("key [%s], from [%s], to [%s], doc_count [%d]", bucket.getKey(), bucket.getFrom(),bucket.getTo(),bucket.getDocCount()));
171 
172     });
173 
174         SearchHits hits = searchResponse1.getHits();
175         for (SearchHit hit : hits) {
176             System.out.println(hit.getSourceAsMap());
177         }
178 
179         System.out.println("---------------------");
180 
181 //
182 //        SearchRequestBuilder searchRequestBuilder1 = client.getConnection().prepareSearch("red88")
183 //                .setTypes("test");
184 ////        QueryBuilder tel = QueryBuilders.boolQuery().should(QueryBuilders.matchQuery("tel","18612855433")).should(QueryBuilders.matchQuery("message","程序设计"));
185 ////        BoolQueryBuilder filter1 = QueryBuilders.boolQuery()//.must(QueryBuilders.matchQuery("age", "40").operator(Operator.AND))
186 ////                .must(QueryBuilders.rangeQuery("age").from(0).to(40))
187 ////                .must(tel);
188 //        searchRequestBuilder.setQuery(QueryBuilders.matchQuery("name","三胖子").operator(Operator.AND));
189 //        BoolQueryBuilder boolQueryBuilder1 = QueryBuilders.boolQuery();
190 //        BoolQueryBuilder queryBuilder1 = QueryBuilders.boolQuery();
191 //        getFilterQuery("tel",new String[]{"18612855433"},"OR",queryBuilder1);
192 //        getFilterQuery("message",new String[]{"程序设计"},"OR",queryBuilder1);
193 //        boolQueryBuilder.must(queryBuilder);
194 //        //boolQueryBuilder.must();
195 //        boolQueryBuilder.must(getRangeFilterQuery("age",new Integer[]{null,40}));
196 //        searchRequestBuilder.setPostFilter(boolQueryBuilder1);
197 //        searchRequestBuilder.setFrom(0);
198 //        searchRequestBuilder.setSize(20);
199 //        searchRequestBuilder.setExplain(true);
200 //        TermsAggregationBuilder aggregationBuilder1 = AggregationBuilders.terms("agg").field("attr_name");
201 //
202 //        aggregationBuilder.size(100);
203 //        searchRequestBuilder.addAggregation(aggregationBuilder);
204 //        searchRequestBuilder.addSort("age",SortOrder.DESC);
205 //
206 
207 
208 
209 
210     }
211 
212     public FunctionScoreQueryBuilder sortByFucntion(QueryBuilder queryBuilder) {
213         FunctionScoreQueryBuilder query = functionScoreQuery(queryBuilder,
214                 ScoreFunctionBuilders.fieldValueFactorFunction("age").modifier(FieldValueFactorFunction.Modifier.LN1P).factor(1f)).boostMode(CombineFunction.SUM);
215         //.add(ScoreFunctionBuilders.fieldValueFactorFunction(查询字段).modifier(Modifier.RECIPROCAL).factor(1)).boostMode(“sum”);
216         return query;
217     }
218     private QueryBuilder getFilterQuery(String fieldName, Object[] fieldValues,String andor,BoolQueryBuilder queryBuilder) {
219         //BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();
220 
221         for (int i = 0; i < fieldValues.length; i++) {
222             if ("OR".equals(andor)){
223                 queryBuilder.should(QueryBuilders.matchQuery(fieldName,fieldValues[i]).operator(Operator.OR));
224             }else if ("AND".equals(andor)){
225                 queryBuilder.must(QueryBuilders.matchQuery(fieldName,fieldValues[i]).operator(Operator.AND));
226             }
227         }
228 
229         return  queryBuilder;
230 
231     }
232     private QueryBuilder getFilterQuery(String fieldName, Object[] fieldValues,String andor) {
233         BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();
234 
235         for (int i = 0; i < fieldValues.length; i++) {
236             if ("OR".equals(andor)){
237                 boolQueryBuilder.should(QueryBuilders.matchQuery(fieldName,fieldValues[i]));
238             }else if ("AND".equals(andor)){
239              boolQueryBuilder.must(QueryBuilders.matchQuery(fieldName,fieldValues[i]));
240             }
241         }
242 
243         return  boolQueryBuilder;
244 
245     }
246 
247     private RangeQueryBuilder getRangeFilterQuery(String fieldName, Integer[] values) {
248         RangeQueryBuilder rangeQueryBuilder = QueryBuilders.rangeQuery(fieldName);
249         rangeQueryBuilder.from(values[0]==null?0:values[0]);
250         rangeQueryBuilder.to((values.length<2||values[1]==null)?99999999:values[1]);
251         return rangeQueryBuilder;
252     }
253 
254 
255     public void multiSearch() {
256 
257         SearchRequestBuilder srb1 = client.getConnection().prepareSearch().setQuery(QueryBuilders.matchQuery("name", "tom")).setSize(1);
258         SearchRequestBuilder srb2 = client.getConnection().prepareSearch().setQuery(QueryBuilders.matchQuery("name", "三胖子")).setSize(1);
259         MultiSearchResponse multiSearchResponse = client.getConnection().prepareMultiSearch()
260                 .add(srb1)
261                 .add(srb2)
262                 .get();
263 
264         for (MultiSearchResponse.Item item : multiSearchResponse.getResponses()) {
265             for (SearchHit hit : item.getResponse().getHits().getHits()) {
266                 System.out.println(hit.getSourceAsMap());
267 
268             }
269         }
270 
271     }
272 
273     public void aggsearch() {
274         SearchRequestBuilder requestBuilder = client.getConnection().prepareSearch("twitter").setTypes("tweet")
275                 .setFrom(0).setSize(100);
276         AggregationBuilder aggregationBuilder = AggregationBuilders.terms("agg").field("name").subAggregation(AggregationBuilders.terms("add").field("age"));
277         SearchResponse response = requestBuilder.setQuery(QueryBuilders.matchQuery("name", "三胖"))
278                 .addAggregation(aggregationBuilder)
279                 .addSort("age", SortOrder.DESC)
280                 .setExplain(true).execute().actionGet();
281         SearchHits searchHits = response.getHits();
282 
283         Terms agg = response.getAggregations().get("agg");
284         Children children = response.getAggregations().get("agg");
285         System.out.println(agg.getBuckets());
286         for (Terms.Bucket bucket : agg.getBuckets()) {
287             System.out.println(bucket.getKey() + ":" + bucket.getDocCount());
288         }
289         System.out.println(children.getAggregations().getAsMap());
290 
291     }
292 
293     public void metricsAgg() {
294 
295         SearchRequestBuilder searchRequestBuilder = client.getConnection().prepareSearch("hello").setTypes("test").setFrom(0).setSize(100);
296         MinAggregationBuilder minAggregationBuilder = AggregationBuilders.min("agg").field("age");
297         SearchResponse response = searchRequestBuilder.setQuery(QueryBuilders.matchAllQuery())
298                 .addAggregation(minAggregationBuilder).setExplain(true).execute().actionGet();
299         Min min = response.getAggregations().get("agg");
300         System.out.println("min:"+min.getValue());
301         MaxAggregationBuilder maxAggregationBuilder = AggregationBuilders.max("max_age").field("age");
302         SearchResponse response1 = searchRequestBuilder.setQuery(QueryBuilders.matchAllQuery())
303                 .addAggregation(maxAggregationBuilder).setExplain(true).execute().actionGet();
304         Max max_age = response1.getAggregations().get("max_age");
305         System.out.println("max:"+max_age.getValue());
306 
307         AvgAggregationBuilder avgAggregationBuilder = AggregationBuilders.avg("avg_age").field("age");
308         SearchResponse response2 = searchRequestBuilder.setQuery(QueryBuilders.matchAllQuery())
309                 .addAggregation(avgAggregationBuilder).setExplain(true).execute().actionGet();
310         Avg avg_age = response2.getAggregations().get("avg_age");
311         System.out.println("avg_age:"+avg_age.getValue());
312 
313         SumAggregationBuilder sumAggregationBuilder = AggregationBuilders.sum("sum_age").field("age");
314         SearchResponse searchResponse = searchRequestBuilder.setQuery(QueryBuilders.matchAllQuery()).addAggregation(sumAggregationBuilder)
315                 .setExplain(true).execute().actionGet();
316         Sum sum_age = searchResponse.getAggregations().get("sum_age");
317         System.out.println("sum_age:"+sum_age.getValue());
318 
319         System.out.println("---------------------------");
320 
321         StatsAggregationBuilder statsAggregationBuilder = AggregationBuilders.stats("agg_status").field("age");
322         SearchResponse searchResponse1 = searchRequestBuilder.setQuery(QueryBuilders.matchAllQuery()).addAggregation(statsAggregationBuilder)
323                 .setExplain(true).execute().actionGet();
324 
325         Stats agg_status = searchResponse1.getAggregations().get("agg_status");
326         double min1 = agg_status.getMin();
327         double max = agg_status.getMax();
328         long count = agg_status.getCount();
329         double sum = agg_status.getSum();
330         double avg = agg_status.getAvg();
331         System.out.println("---------------------------------");
332         System.out.println("min1="+min1);
333         System.out.println("max="+max);
334         System.out.println("count="+count);
335         System.out.println("sum="+sum);
336         System.out.println("avg="+avg);
337 
338         ExtendedStatsAggregationBuilder extendedStatsAggregationBuilder = AggregationBuilders.extendedStats("extend_status").field("age");
339 
340         SearchResponse searchResponse2 = searchRequestBuilder.setQuery(QueryBuilders.matchAllQuery()).addAggregation(extendedStatsAggregationBuilder).setExplain(true).execute().actionGet();
341         ExtendedStats extend_status = searchResponse2.getAggregations().get("extend_status");
342         double extend_min = extend_status.getMin();
343         double extend_max = extend_status.getMax();
344         long extend_count = extend_status.getCount();
345         double extend_sum = extend_status.getSum();
346         double extend_avg = extend_status.getAvg();
347         System.out.println("---------------------------------");
348         System.out.println("extend_min="+extend_min);
349         System.out.println("extend_max="+extend_max);
350         System.out.println("extend_count="+extend_count);
351         System.out.println("extend_sum="+extend_sum);
352         System.out.println("extend_avg="+extend_avg);
353 
354 
355     }
356 }

 

3.1 controller层实现

IndexController
 1 package com.elastic.controller;
 2 
 3 import com.elastic.service.inter.IndexService;
 4 import org.springframework.beans.factory.annotation.Autowired;
 5 import org.springframework.stereotype.Controller;
 6 import org.springframework.web.bind.annotation.RequestMapping;
 7 
 8 import javax.servlet.http.HttpServletRequest;
 9 import javax.servlet.http.HttpServletResponse;
10 import java.io.IOException;
11 
12 /**
13  * Created by xiaotian on 2017/12/1.
14  */
15 @Controller
16 public class IndexController {
17 
18     @Autowired
19     private IndexService indexService;
20 
21     @RequestMapping("/index")
22     public  void index(HttpServletRequest request, HttpServletResponse response) throws IOException {
23 
24         indexService.index(request.getParameter("id"));
25     }
26     @RequestMapping("/get")
27     public  void get(){
28 
29         indexService.get();
30     }
31 
32     @RequestMapping("/del")
33     public  void get(HttpServletRequest request, HttpServletResponse response) throws IOException {
34 
35         indexService.del(request.getParameter("id"));
36     }
37     @RequestMapping("/update")
38     public  void update(HttpServletRequest request, HttpServletResponse response) throws Exception {
39 
40         indexService.update(request.getParameter("id"));
41     }
42     @RequestMapping("/multiGet")
43     public  void multiGet(HttpServletRequest request, HttpServletResponse response) throws Exception {
44 
45         indexService.multiGet(request.getParameter("id").split(","));
46     }
47     @RequestMapping("/bulk")
48     public  void bulk(HttpServletRequest request, HttpServletResponse response) throws Exception {
49 
50         indexService.bulk(request.getParameter("id").split(","));
51     }
52     @RequestMapping("/bulkP")
53     public  void bulkProcesstor(HttpServletRequest request, HttpServletResponse response) throws Exception {
54         String index = request.getParameter("index");
55         String type = request.getParameter("type");
56         String[] ids = request.getParameter("id").split(",");
57         indexService.bulkProcesstor(index,type,ids);
58     }
59 }
SearchController
 1 package com.elastic.controller;
 2 
 3 import com.elastic.service.inter.SearchService;
 4 import org.springframework.beans.factory.annotation.Autowired;
 5 import org.springframework.stereotype.Controller;
 6 import org.springframework.web.bind.annotation.RequestMapping;
 7 
 8 import javax.servlet.http.HttpServletRequest;
 9 import javax.servlet.http.HttpServletResponse;
10 import java.io.IOException;
11 
12 /**
13  * Created by xiaotian on 2017/12/2.
14  */
15 @Controller
16 public class SearchController {
17 
18     @Autowired
19     private SearchService searchService;
20     @RequestMapping("/search")
21     public  void index(HttpServletRequest request, HttpServletResponse response) throws IOException {
22 
23         searchService.search();
24     }
25     @RequestMapping("/multiSearch")
26     public  void multiSearch(HttpServletRequest request, HttpServletResponse response) throws IOException {
27 
28         searchService.multiSearch();
29     }
30     @RequestMapping("/aggsearch")
31     public  void aggsearch(HttpServletRequest request, HttpServletResponse response) throws IOException {
32 
33         searchService.aggsearch();
34     }
35 
36     @RequestMapping("/metricsAgg")
37     public  void metricsAgg(HttpServletRequest request, HttpServletResponse response) throws IOException {
38 
39         searchService.metricsAgg();
40     }
41     @RequestMapping("/searchFilter")
42     public  void searchByCondition(HttpServletRequest request, HttpServletResponse response) throws Exception {
43 
44         searchService.searchByCondition();
45     }
46 }

4. 通过kibana进行索引建立和查询等

  1 GET red89/test/_search
  2 
  3 {
  4   "from" : 0,
  5   "size" : 20,
  6   "query" : {
  7     "match" : {
  8       "name" : {
  9         "query" : "中华",
 10         "operator" : "AND",
 11         "prefix_length" : 0,
 12         "max_expansions" : 50,
 13         "fuzzy_transpositions" : true,
 14         "lenient" : false,
 15         "zero_terms_query" : "NONE",
 16         "boost" : 1.0
 17       }
 18     }
 19   },
 20   "post_filter" : {
 21     "bool" : {
 22       "must" : [
 23         {
 24           "bool" : {
 25             "should" : [
 26               {
 27                 "match" : {
 28                   "tel" : {
 29                     "query" : "18612855433",
 30                     "operator" : "OR",
 31                     "prefix_length" : 0,
 32                     "max_expansions" : 50,
 33                     "fuzzy_transpositions" : true,
 34                     "lenient" : false,
 35                     "zero_terms_query" : "NONE",
 36                     "boost" : 1.0
 37                   }
 38                 }
 39               }
 40             ],
 41             "adjust_pure_negative" : true,
 42             "boost" : 1.0
 43           }
 44         },
 45         {
 46           "range" : {
 47             "age" : {
 48               "from" : 0,
 49               "to" : 45,
 50               "include_lower" : true,
 51               "include_upper" : true,
 52               "boost" : 1.0
 53             }
 54           }
 55         }
 56       ],
 57       "adjust_pure_negative" : true,
 58       "boost" : 1.0
 59     }
 60   },
 61   "explain" : true,
 62   "aggregations" : {
 63     "agg" : {
 64       "filter" : {
 65         "bool" : {
 66           "must" : [
 67             {
 68               "bool" : {
 69                 "should" : [
 70                   {
 71                     "match" : {
 72                       "tel" : {
 73                         "query" : "18612855433",
 74                         "operator" : "OR",
 75                         "prefix_length" : 0,
 76                         "max_expansions" : 50,
 77                         "fuzzy_transpositions" : true,
 78                         "lenient" : false,
 79                         "zero_terms_query" : "NONE",
 80                         "boost" : 1.0
 81                       }
 82                     }
 83                   }
 84                 ],
 85                 "adjust_pure_negative" : true,
 86                 "boost" : 1.0
 87               }
 88             },
 89             {
 90               "range" : {
 91                 "age" : {
 92                   "from" : 0,
 93                   "to" : 45,
 94                   "include_lower" : true,
 95                   "include_upper" : true,
 96                   "boost" : 1.0
 97                 }
 98               }
 99             }
100           ],
101           "adjust_pure_negative" : true,
102           "boost" : 1.0
103         }
104       },
105       "aggregations" : {
106         "agg" : {
107           "terms" : {
108             "field" : "attr_name",
109             "size" : 100,
110             "min_doc_count" : 1,
111             "shard_min_doc_count" : 0,
112             "show_term_doc_count_error" : false,
113             "order" : [
114               {
115                 "_count" : "desc"
116               },
117               {
118                 "_key" : "asc"
119               }
120             ]
121           }
122         }
123       }
124     },
125     "range" : {
126       "range" : {
127         "field" : "age",
128         "ranges" : [
129           {
130             "from" : 0.0,
131             "to" : 30.0
132           },
133           {
134             "from" : 30.0,
135             "to" : 50.0
136           },
137           {
138             "from" : 50.0,
139             "to" : 100.0
140           }
141         ],
142         "keyed" : false
143       }
144     }
145   }
146 }

查询结果:

  1 {
  2   "took": 1,
  3   "timed_out": false,
  4   "_shards": {
  5     "total": 5,
  6     "successful": 5,
  7     "skipped": 0,
  8     "failed": 0
  9   },
 10   "hits": {
 11     "total": 21,
 12     "max_score": 1,
 13     "hits": [
 14       {
 15         "_index": "red89",
 16         "_type": "test",
 17         "_id": "14",
 18         "_score": 1,
 19         "_source": {
 20           "date": "2017-12-11T09:55:42.261Z",
 21           "attr_name": [
 22             "品牌_sku_attr14",
 23             "商品类别_sku_attr14",
 24             "面料_sku_attr14"
 25           ],
 26           "name": "中华人民共和国14",
 27           "tel": "18612855433",
 28           "message": "程序设计14",
 29           "create_date": "2017-12-11T09:55:42.261Z",
 30           "age": 44
 31         }
 32       },
 33       {
 34         "_index": "red89",
 35         "_type": "test",
 36         "_id": "19",
 37         "_score": 1,
 38         "_source": {
 39           "date": "2017-12-11T09:55:42.261Z",
 40           "attr_name": [
 41             "品牌_sku_attr19",
 42             "商品类别_sku_attr19",
 43             "面料_sku_attr19"
 44           ],
 45           "name": "中华人民共和国19",
 46           "tel": "18612855433",
 47           "message": "程序设计19",
 48           "create_date": "2017-12-11T09:55:42.261Z",
 49           "age": 49
 50         }
 51       },
 52       {
 53         "_index": "red89",
 54         "_type": "test",
 55         "_id": "5",
 56         "_score": 1,
 57         "_source": {
 58           "date": "2017-12-11T09:55:42.257Z",
 59           "attr_name": [
 60             "品牌_sku_attr5",
 61             "商品类别_sku_attr5",
 62             "面料_sku_attr5"
 63           ],
 64           "name": "中华人民共和国5",
 65           "tel": "18612855433",
 66           "message": "程序设计5",
 67           "create_date": "2017-12-11T09:55:42.257Z",
 68           "age": 35
 69         }
 70       },
 71       {
 72         "_index": "red89",
 73         "_type": "test",
 74         "_id": "8",
 75         "_score": 1,
 76         "_source": {
 77           "date": "2017-12-11T09:55:42.257Z",
 78           "attr_name": [
 79             "品牌_sku_attr8",
 80             "商品类别_sku_attr8",
 81             "面料_sku_attr8"
 82           ],
 83           "name": "中华人民共和国8",
 84           "tel": "18612855433",
 85           "message": "程序设计8",
 86           "create_date": "2017-12-11T09:55:42.257Z",
 87           "age": 38
 88         }
 89       },
 90       {
 91         "_index": "red89",
 92         "_type": "test",
 93         "_id": "9",
 94         "_score": 1,
 95         "_source": {
 96           "date": "2017-12-11T09:55:42.257Z",
 97           "attr_name": [
 98             "品牌_sku_attr9",
 99             "商品类别_sku_attr9",
100             "面料_sku_attr9"
101           ],
102           "name": "中华人民共和国9",
103           "tel": "18612855433",
104           "message": "程序设计9",
105           "create_date": "2017-12-11T09:55:42.257Z",
106           "age": 39
107         }
108       },
109       {
110         "_index": "red89",
111         "_type": "test",
112         "_id": "10",
113         "_score": 1,
114         "_source": {
115           "date": "2017-12-11T09:55:42.257Z",
116           "attr_name": [
117             "品牌_sku_attr10",
118             "商品类别_sku_attr10",
119             "面料_sku_attr10"
120           ],
121           "name": "中华人民共和国10",
122           "tel": "18612855433",
123           "message": "程序设计10",
124           "create_date": "2017-12-11T09:55:42.257Z",
125           "age": 40
126         }
127       },
128       {
129         "_index": "red89",
130         "_type": "test",
131         "_id": "12",
132         "_score": 1,
133         "_source": {
134           "date": "2017-12-11T09:55:42.261Z",
135           "attr_name": [
136             "品牌_sku_attr12",
137             "商品类别_sku_attr12",
138             "面料_sku_attr12"
139           ],
140           "name": "中华人民共和国12",
141           "tel": "18612855433",
142           "message": "程序设计12",
143           "create_date": "2017-12-11T09:55:42.261Z",
144           "age": 42
145         }
146       },
147       {
148         "_index": "red89",
149         "_type": "test",
150         "_id": "ZraQK2ABrThwqnonhOO3",
151         "_score": 1,
152         "_source": {}
153       },
154       {
155         "_index": "red89",
156         "_type": "test",
157         "_id": "2",
158         "_score": 1,
159         "_source": {
160           "date": "2017-12-11T09:55:42.256Z",
161           "attr_name": [
162             "品牌_sku_attr2",
163             "商品类别_sku_attr2",
164             "面料_sku_attr2"
165           ],
166           "name": "中华人民共和国2",
167           "tel": "18612855433",
168           "message": "程序设计2",
169           "create_date": "2017-12-11T09:55:42.256Z",
170           "age": 32
171         }
172       },
173       {
174         "_index": "red89",
175         "_type": "test",
176         "_id": "4",
177         "_score": 1,
178         "_source": {
179           "date": "2017-12-11T09:55:42.257Z",
180           "attr_name": [
181             "品牌_sku_attr4",
182             "商品类别_sku_attr4",
183             "面料_sku_attr4"
184           ],
185           "name": "中华人民共和国4",
186           "tel": "18612855433",
187           "message": "程序设计4",
188           "create_date": "2017-12-11T09:55:42.257Z",
189           "age": 34
190         }
191       }
192     ]
193   }
194 }

 

posted @ 2017-12-21 17:15  霄九天  阅读(16731)  评论(2编辑  收藏  举报