Elasticsearch拆分java api生成restful json代码 博客分类: java;nosql;elasticsearch javanosqlelasticsearch
程序员文章站
2024-03-15 09:52:05
...
项目中用到ElasticSearch 1.4.2,但多个项目生产环境使用的jdk版本不一致,大部分都是1.6。
折中方案使用restful api,但query json写起来比较麻烦,想用java api的方式写代码,最终生成restful json。
看了几个开源项目,如jest,还是需要RD自己写json,或者用ES提供的类SearchSourceBuilder。
比较蛋疼的是,ElasticSearch没有对功能进行拆包,还是跨不过jdk版本的问题。
无奈只好从ES的代码中拆分出这部分代码,并且支持jdk1.6编译执行。
代码已经拆分出来了,但没有精细化的整理,还是存在一些不必要的检索逻辑。
稍后加上HttpClient,就可以写java api通过restful接口进行调用了。
Git:https://github.com/mazhen2010/rts-es-rest4j
折中方案使用restful api,但query json写起来比较麻烦,想用java api的方式写代码,最终生成restful json。
看了几个开源项目,如jest,还是需要RD自己写json,或者用ES提供的类SearchSourceBuilder。
比较蛋疼的是,ElasticSearch没有对功能进行拆包,还是跨不过jdk版本的问题。
无奈只好从ES的代码中拆分出这部分代码,并且支持jdk1.6编译执行。
代码已经拆分出来了,但没有精细化的整理,还是存在一些不必要的检索逻辑。
稍后加上HttpClient,就可以写java api通过restful接口进行调用了。
Git:https://github.com/mazhen2010/rts-es-rest4j
public class SearchSourceBuilderTest { @Test public void testJson() { QueryBuilder query = QueryBuilders.matchQuery("firmName", "清泉"); FilterBuilder stationFilter = FilterBuilders.termFilter("stationId", 5); FilterBuilder staffFilter = FilterBuilders.termFilter("staffId", 936); query = QueryBuilders.filteredQuery(query, FilterBuilders.andFilter(stationFilter).add(staffFilter)); SortBuilder dealSorter = SortBuilders.fieldSort("dealCount").order(SortOrder.ASC); SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder(); String json = searchSourceBuilder.query(query).toString(); System.out.println(json); } }