昨日运营同学提了个问题,table的模糊查询只支持当前页,查询时需要一页一页的翻,用户体验度有待提高。
技术层面是因为查询调用公共的public Pagination pageQuery(final Criterion[] criterions, final Integer startLine, final Integer pageSize, final String orderBy, final boolean isAsc){}方法,该方法对单表查询支持比较不错,把查询条件添加到Criterion数组,执行pageQuery便可以进行各种组合查询,但对多表查询无过多说明。
用jd-gui反编译工具,我找到了public Pagination pageQuery(final String hql, final Integer startLine, final Integer pageSize){}方法,可以动态组装hql查询语句,虽然麻烦,但灵活性比较好。因此我对原有代码进行重构,用hql实现多表查询。
我们有一个主表App,它有id、name两个字段;一个从表AppExtend,它有id、appId、phoneUrl三个字段。我们要实现的是AppExtend通过appId字段关联App表,模糊查询App的name字段,并且AppExtend的phoneUrl字段不为空。
首先我们在AppExtend用OneToOne声明和App的关系:
@Entity(name = "v4_app_extend")
@Data<