JPA 支持多参数列表查询(参数可能为空)

  1. JPA 支持写sql语句查询
    @Query(value = "select * from xxx ",nativeQuery = true)

  2. JPA @Query的sql语句可以通过?1、?2这样获取查询方法里第一个参数、第二个参数,以此类推;或者是使用@Param(“name”)标识参数,然后使用 :name 获取。

  3. mysql 的if函数,类似三目运算
    if(sex=1, ‘男’ , ‘女’)

结合起来可以使用mysql的if函数,来判断参数是否为空,为空时设置1=1,也就是查所有。

第一种方式: ?1获取参数
@Query(value = "select * from test_demo where if(?1 !=’’,name=?1,1=1) and if(?2 !=’’,info=?2,1=1) ",nativeQuery = true)
List find(String name, String info) ;

第二种方式::name获取参数
@Query(value = "select * from test_demo where if(:name !=’’,name= :name,1=1) and if(:info !=’’,info= :info,1=1) ",nativeQuery = true)
List find2(@Param(“name”) String name, @Param(“info”) String info) ;

第三种方式:实体类获取参数
@Query(value = "select * from test_demo where if(:#{#testDemo.name} !=’’,name=:#{#testDemo.name},1=1) and if(:#{#testDemo.info} !=’’,info=:#{#testDemo.info},1=1) ",nativeQuery = true)
List find3(@Param(“testDemo”)TestDemo testDemo) ;

这三种写法结果是一样的,主要逻辑就是使用mysql的if函数,判断某个字段是否不为空,是的话就根据这个字段查询,否则就1=1(为了保证sql语句可以执行)。

同理可以拓展很多,包括模糊查询等,只要MySQL 支持的sql语句就可以使用JPA来实现,同时JPA特有的分页也可以实现只需要传递Pageable对象并使用Page 接收数据即可。
@Query(value = "select * from test_demo where if(?1 !=’’,name=?1,1=1) and if(?2 !=’’,info=?2,1=1) ",nativeQuery = true)
Page find(String name, String info, Pageable pageable) ;

你可能感兴趣的:(java)