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