Elasticsearch ORM 框架,EsearchX v1.0.22 发布

EsearchX for java 是基于 okhttp + snack3 开发的,一个代码直白和简单的 Elasticsearch ORM 框架。

  • 支持 jdk8、jdk11、jdk17、jdk20
  • 支持 es7.x、es8.x
  • 采用 lambda 链式写法,很是清新
public class DemoApp {
    public void demo() {
        EsContext esx = new EsContext("localhost:30480");
  
        //批量插入
        List<LogDo> list = new ArrayList<>();
        list.add(new LogDo());
        esx.indice("user_log").insertList(list);
        
        //一个简单的查询
        LogDo result = esx.indice("user_log").selectById(LogDo.class, "1");
        
        //一个略复杂些的查询
        EsData<LogDo> result = esx.indice(indice)
                .where(c -> c.useScore().must()
                        .term("tag", "list1")
                        .range("level", r -> r.gt(3)))
                .orderByAsc("level")
                .andByAsc("log_id")
                .minScore(1)
                .limit(50, 50)
                .selectList(LogDo.class);
    } 
}

本次更新:

  • snack 升级为:3.2.66
  • EsAggs 增加别名支持
ONode oNode = context.indice(indice)
                .where(c -> c.range("grade", r -> r.gte(3)))
                .limit(0)
                .aggs(a -> a.min("grade", "grade")) //别名
                .selectAggs();

long gradeMin = oNode.get("grade").get("value").getLong();       

项目仓库:

猜你喜欢

转载自www.oschina.net/news/240087/esearchx-1-0-22-released