聊聊Spring data jpa @query使用原生SQl,需要注意的坑

网友投稿 2502 2022-12-14

聊聊Spring data jpa @query使用原生SQl,需要注意的坑

聊聊Spring data jpa @query使用原生SQl,需要注意的坑

目录Spring data jpa @Query 使用原生Sql的坑根据代码来解说:需要注意的方法有以下几点SpringData JPA @Query动态SQL语句思路实现

Spring data jpa @Query 使用原生Sql的坑

根据代码来解说:

@Query(value = "select bill.id_ as id, bill.created_date as date, bill.no, lawyer_case .case_no as caseNo, " +

"lawyer_case .case_name as caseName, customer.no as customerNo, customer-_name as customerName, " +

"bill.total_expense_after_tax, bill.collected_money, bill.book_ticket_amount, bill.version " +

"e1.name as creator, bill.status" +

"from bill " +

"left join lawyer_case on lawyer_case .case_no=bill.case_no " +

"left join customer on customer.no=bill.customer_no " +

"left join employee e1 on e1.id_=bill.creator " +

"where IF (?1!='', customer_no=?1, 1=1) " +

"and IF (?2!='', case_no=?2, 1=1) " +

"and IF (?3!='', status=?3, 1=1) " +

"and IF (?4!='', creator'%',?4,'%')), 1=1) " +

"and create_by=?5 " +

"ORDER BY ?#{#pageable} ",

countQuery = "select count(*) " +

"from bill " +

"left join lawyer_case on lawyer_case .case_no=bill.case_no " +

"left join customer on customer.no=bill.customer_no " +

"left join employee e1 on e1.id_=bill.creator " +

"where IF (?1!='', customer_no=?1, 1=1) " +

"and IF (?2!='', case_no=?2, 1=1) " +

"and IF (?3!='', status=?3, 1=1) " +

"and IF (?4!='', creator'%',?4,'%')), 1=1) " +

"and create_by=?5 "+

"ORDER BY ?#{#pageable} ",

nativehttp://Query = true)

Page findAllBill(String customerNo, String caseNo, Integer status, String creator,

String createBy, Pageable pageable);

需要注意的方法有以下几点

1、From 不支持重命名.

2、返回的是一个page,数组中只保存了数据,没有对应的key,只能根据返回数据的顺序,依次注入到DTO中。

3、对于使用分页,需要:“ORDER BY ?#{#pageable}”,可以直接传入一个pageable对象,会自动解析

4、注意格式问题,很多时候就是换行的时候,没有空格。

5、仔细对应数据库中表字段,很多时候报某个字段找不到,就是因为字段名写错,和数据库中对应不上。

6、这是解决使用微服务,大量的数据都需要远程调用,会降低程序的性能。

7、使用Pageabel作为参数的时候,去进行分页。刚开始的时候,觉得还是一个可行的办法,但是得注意的时候,当需要排序的时候,是无法加入sort字段的。 会一直报错left*。

8、针对7的解决方案,把原生SQL的数据查询和countQuery分成两个查询方法。得到count,然后进行判断,若是等于0,则直接返回空集合;反之,则取获取数据。 需要自己进行分页计算,传入正确的pageNumber和pageSize。

大部分系统都是按照修改时间进行降序排序。 所以,order by可以写死。然后pageNumber和pageSize动态传入。

pageNumber的算法= (pageNumber - 1) * http://pageSize, 前提是PageNumber是从1开始,若0,则pageNumber=pageNumber * PageSize; 这样就可以保证数据的正确。

/**

* pageInfos: 转换之后的数据。

* pageable:传入的pageable.

* totalPage: 第一条SQL算好的返回值。

* 这样就可以统一的返回各种pageDTO。

*/

private Page pageInfos, Pageable pageable, Integer totalPage) {

return new PageImpl<>(pageInfos, pageable, totalPage);

}

SpringData JPA @Query动态SQL语句

这次有个需求,需要动态的sql语句去查询,但是@Query正常情况下SQL语句是写死的,在查找了很多资料后,想到了一个好的解决办法

思路

利用mysql的判断来拼接SQL语句

实现

先上代码

@Query(value = "select * from project_demand where project_id=?1 and if(?2!='',demand_id in (select demand_id from demand_user where user_id=?2),1=1)",nativeQuery = true)

List getListByUser(String projectId,String userId);

红色部分

,就是生成动态SQL的方法,利用MYSQL的if函数和我们传递的参数去进行判断,然后获取SQL语句。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:springboot清除字符串前后空格与防xss攻击方法
下一篇:@Query注解的原生用法和native用法解析
相关文章

 发表评论

暂时没有评论,来抢沙发吧~