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将会给予一定提示。如下实例:
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?