Spring Data JPA应用之查询分析
在Spring Data JPA应用之查询操作初体验中提供了三种查询的方式,测试时使用了一种方式而且不是接口中编码的。为什么呢?在其文尾附上了JpaRepository接口继承关系及方法,可以知道JpaRepository提供了基本的CRUD操作——即当使用JPA时,对于简单的增、删、查、改等功能几乎不需要再编写代码,只需继承JpaRepository就可以实现。
通过该图还可以断定继承了JpaRepository的接口已经具备了分页数据查询功能且对于该接口无需实现,项目启动时Spring Data会通过动态代码生成机制创建该接口的具体实现类并注册到Spring应用上下文中。
此外,Spring Data还提供了自然语义的数据访问机制(Spring Data JPA应用之查询操作初体验中测试采用的就是该种方式)。但是综合而言对于稍微复杂一些的查询可能由于需要自定义的方法比较长等,这种机制不太友好。所以JPA还提供了几类复杂查询方式,如下:
一、引入JPQL(jpa查询语言)
通过语句可以看出其与SQL的区别:jpql操作的是对象及其属性。如上图中from后直接操作的是Resume,在实体类中有具体标记。
二、引入sql查询
使⽤原⽣sql语句查询,需要将nativeQuery属性设置为true,默认为false(jpql)。
三、方法命名规则方式查询
Spring Data JPA支持通过定义在Repository接口中的方法来定义查询,而方法名是根据实体类的属性名来确定的。
这个方法相当于JPQL:"from XXX where name like?1 and address=?2 "
从代码可以看出,使用了findBy/Like/And这样的关键字。其中find也可以用find/read/query/get等字段代替。这类查询关键字还有很多,如下:
使用集成工具开发,比如Idea将会给予一定提示。如下实例: