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异常

JavaEE 之 Spring Data JPA

Spring Data 系列 Spring+JPA(spring-data-commons)

java web spring jpa 在以接口为dao的方法里使用原生sql,联合查找没有对应实体,用啥来接收? 求大神

Spring data JPA,复杂原生Query

Spring Data JPA中踩过的坑