Bootstrap

JPA Specification匿名内部类应用讲解

首先我们都知道,Specification接口是在JPA进行动态拼接查询的,而我们一般会重写里面的Predicate方法来真正实现里面的功能。

现在就来详细的说一下这个方法的具体使用方法。

举一个简单的实例,我们有一个实例类叫做Label,有两个字段叫labelname和state,然后我们展开以下的动态查询:

  1. 先将匿名内部类中的toPredicate方法实现出来,我们可以看见,这里有几个看不懂的参数,所以我先解释一下这里面的参数都是什么意思
  • root : 根对象。相当于泛型本身,意思是我们将针对哪张表展开动态拼接查询。类似于where Label = xxx
  • query :封装了一些查询的关键字,如group by,order by
  • criteriaBuilder:用来拼接上面你所构造出来的一系列的限制条件,用and或者or去拼接起来

在这里插入图片描述

  1. 我们可以很明显的看出,传过来的是一个model,事实上也是如此,一般我们动态拼接查找,传过来的参数,一般都是集合属性,或者一整个对象全部传过来。
     
    那么,这样就存在一种情况,我传过来的值可能有是空的字段,那么我们在构建查询的时候,就要注意这一点,换句话讲,要先判空,然后再去拼接。
     

在这里插入图片描述
这中间要说的,就只有:

(1)as:用来指定你从root里获取到的对象的某个属性,是属于什么类型的
(2)and:拼接我们所有的查询条件

  1. 最后一步:拼接查找条件的方法,我们可以用List是比较常见的,然后再转型成Predicate内部要求的类型就可以了。

在这里插入图片描述

;