亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Spring data jpa @query使用原生SQl時需要注意的問題

發布時間:2021-08-30 09:38:45 來源:億速云 閱讀:590 作者:chen 欄目:開發技術

本篇內容介紹了“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.cn_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} ",
            nativeQuery = true)
    Page<Object[]> findAllBill(String customerNo, String caseNo, Integer status, String creator,
                               String createBy, Pageable pageable);

需要注意的方法有以下幾點

  • 1、From 不支持重命名.

  • 2、返回的是一個page<Object[]>,數組中只保存了數據,沒有對應的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) * pageSize, 前提是PageNumber是從1開始,若0,則pageNumber=pageNumber * PageSize; 這樣就可以保證數據的正確。

/**
* pageInfos: 轉換之后的數據。
* pageable:傳入的pageable.
* totalPage: 第一條SQL算好的返回值。
* 這樣就可以統一的返回各種pageDTO。
*/
private Page<T> convertForPage(List<T> 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<ProjectDemand> getListByUser(String projectId,String userId);

Spring data jpa @query使用原生SQl時需要注意的問題

紅色部分,就是生成動態SQL的方法,利用MYSQL的if函數和我們傳遞的參數去進行判斷,然后獲取SQL語句。

“Spring data jpa @query使用原生SQl時需要注意的問題”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

雷州市| 井冈山市| 北辰区| 多伦县| 无为县| 崇仁县| 岑溪市| 东兰县| 射洪县| 永善县| 广元市| 抚远县| 旬邑县| 武冈市| 云和县| 合阳县| 仙居县| 遵义县| 大城县| 绵竹市| 保亭| 临邑县| 岐山县| 青浦区| 渝中区| 江源县| 博爱县| 聊城市| 仁寿县| 南部县| 桐梓县| 江津市| 延长县| 叶城县| 昂仁县| 白河县| 达州市| 社旗县| 尚志市| 桐庐县| 长子县|