项目中用到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
class="java" name="code">
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);
}
}
- rts_es_rest4j-1.0.0.0-SNAPSHOT.jar (680.3 KB)
- 下载次数: 0