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

  1. JPA 支持写SQL语句查询
@Query(value = "select * from xxx ",nativeQuery = true)
  1. JPA @Query的SQL语句可以通过?1、?2这样获取查询方法里第一个参数、第二个参数,以此类推;或者是使用@Param("name")标识参数,然后使用 :name 获取。

  2. 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<TestDemo> 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<TestDemo> 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<TestDemo> 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<TestDemo> find(String name, String info, Pageable pageable) ;
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值