Spring Data JPA 之 原生SQL使用
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Spring Data JPA 之 原生SQL使用相关的知识,希望对你有一定的参考价值。
参考技术A spring data jpa 提供了强大的接口,一般情况下,接口默认提供的方法即可满足查询需求,但是一些特定场合我们还是需要使用自定义SQL查询。此处定义了一个参数的自定义sql查询,age的数值作为参数进行查询
测试下自定义查询SQL的接口
总的来说绝大多数的单表条件查询,都可以用JPA接口非常方便的表述出来,但是有些场景下如果需要自定义语句,则可以按照本文的方式进行自定义SQL接口查询。
JavaEE 之 Spring Data JPA
1.JPQL
a.定义:Java持久化查询语言(JPQL)是一种可移植的查询语言,旨在以面向对象表达式语言的表达式,将SQL语法和简单查询语义绑定在一起·使用这种语言编写的查询是可移植的,可以被编译成所有主流数据库服务器上的SQL。
b.语句:
select u from User u where u.userId=?
2.一对一(OneToOne)
a.UserInfo类拥有User属性(含有user_id外键)
@OneToOne @JoinColumn(name="user_id") private User user;
b.User类拥有UserInfo属性
@OneToOne(mappedBy="user") //谁来维护关系 private UserInfo info;
c.jpql语句
select u from User u left join u.info where u.userId=?
3.一对多(OneToMany)
a.UserInfo类拥有User属性(多方)
@ManyToOne @JoinColumn(name="user_id") private User user; // one 2 one 一定有一方维持关系 谁做外键谁维护
b.User类拥有List<UserInfo>属性(单方)
@OneToMany(mappedBy="user") private List<UserInfo> infos;
c.jpql语句
select u from User u left join fetch u.infos where u.userId=?
以上是关于Spring Data JPA 之 原生SQL使用的主要内容,如果未能解决你的问题,请参考以下文章
Spring data jpa,原生查询Hibernate异常
Spring Data 系列 Spring+JPA(spring-data-commons)
java web spring jpa 在以接口为dao的方法里使用原生sql,联合查找没有对应实体,用啥来接收? 求大神