jpa动态sql

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了jpa动态sql相关的知识,希望对你有一定的参考价值。

参考技术A 以上两种是定义DAO的实现类。在实现类中写查询方法,第一种需要注入EntityManager,第二种需要注入JpaQueryFactory。

下面在接口中写动态sql

实现类和接口方式组合。下列接口StudentDao就具有了selectCustom方法

jpa 如何优雅的实现动态sql

案例

    动态语言注解
    import www.ijava.com.entity.User;
    /*
    * (1)动态语言注解

    对于创建动态的查的语言。MyBatis提供了多个注解如:
    @InsertProvider,
    @UpdateProvider,
    @DeleteProvider和
    @SelectProvider,
    这些都是建立动态语言和让MyBatis执行这些语言。
    (2)@Provider使用思路

    对于MyBatis提供的几个@Provider,
    里面最主要的参数是type,
    也就是sql类的Calss对象,
    另外就是对应的方法名,
    我们看SelectProvider的源代码:
    @Documented
    @Retention(RetentionPolicy.RUNTIME)
    @Target(ElementType.METHOD)
    public @interface SelectProvider
    Class<?> type();

    String method();

    所以要实现动态的SQL查询,那么大体的思路就是,编写一个SqlProvider,比如:DemoSqlProvider,在此方法中返回一条SQL语句即可。然后在Mapper类中使用@SelectProvider注解,指定provider类和对应的SQL方法。

    问题:有一个表中有id,name,email等字段,有这么一个查询要求:我们希望的是如果name不为null的话,那么就当做条件,否则就不要当做条件;如果email不为null,那么就当做条件,否则不当做条件。

    接下里看看怎么使用@SelectProvider破。

    Provider:供应者
    */

    public class UserSqlProvider

    /**
    * 查询语句.
    */
    public String select1(User user )

    StringBuffer sql = new StringBuffer("select * from tb_user1 where 1=1 ");
    if(user.getAge() != 0)
    sql.append(" and age=#age");

    if(user.getUsername() != null)
    if("张三----".contains(user.getUsername()))
    sql.append(" and username=#username");




    return sql.toString();



    UserMapper

    @SelectProvider(type=UserSqlProvider.class,method="select1")
    List<User> getUserByIdAndUsername(User user);

参考技术A like a flower blooming, quivering, and fi

以上是关于jpa动态sql的主要内容,如果未能解决你的问题,请参考以下文章

基于Spring Boot,使用JPA动态调用Sql查询数据

如何在 JPA 中编写动态 sql 查询以从 jsonb 列中查询数据?

spring-data-jpa的简单使用动态sql分页排序

使用dapper时动态拼接查询sql有啥好的方法吗

JPA表单动态传参

Jdbc多数据源动态切换项目