<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-95  評論-31  文章-10  trackbacks-0
    問題:
    1:一般情況下,用spring-boot data jpa查詢sql稍有點多,本來一條sql解決的事情,一定要幾條, 如何優化成一條sql解決,還能帶上分頁?
    2:這個時候@Query注解里面的nativeQuery就可以派上用場 (用left join fetch也可以優化成一條sql,見http://m.tkk7.com/liuguly/archive/2017/11/13/432890.html)
    3:nativeQuery的用途是可以使用原生sql。

    經過實踐,官網給出的示例無法跑通:


    解決方法:
    1: 先按照上述官網示例進行配置。
    2: 示例:
    @Repository
    public interface BabySittingDao extends PagingAndSortingRepository<BabySitting, Long> {

        /**
         * 獲取喜歡的sharecare列表
         * 
    @param accountId 當前用戶id
         * 
    @param fType 喜歡的類型  0-> sharecare  1-> babysitting  2->event
         * 
    @param pageable 分頁
         * 
    @return 分頁結果
         
    */
        @Query(value = "SELECT s.* FROM sharecare.sb_baby_sitting s WHERE s.id IN (" +
                "SELECT f.f_type_id FROM sharecare.sb_favorite f WHERE f.f_type=?2 AND f.owner_id=?1)  ORDER BY ?#{#pageable}",
                countQuery = "SELECT COUNT (*) FROM  (SELECT s.* FROM sharecare.sb_baby_sitting s WHERE s.id IN " +
                        "(SELECT f.f_type_id FROM sharecare.sb_favorite f WHERE f.f_type=?2 AND f.owner_id=?1))",
                nativeQuery = true)
        Page<BabySitting> findFavoriteBabySitting(Long accountId, Integer fType, Pageable pageable);

    說明:@Query里面的value是原生sql 、countQuery表示查詢總數、nativeQuery表示這是一條原生sql

    注意點:
    1: 這個接口方法findFavoriteBabySitting一定要放在當前領域模型的Dao接口里面,不能放在其它Dao接口中,否則就是網上流傳的類型轉換錯誤!
    2: 見紅色標注,一定要這樣寫,不能ORDER BY ?3這樣寫,也不能ORDER BY #{#pageable}這樣寫,否則就是網上流傳的各種錯!
    3: 一定要加nativeQuery=true

    經過以上配置,就可正確查詢出結果且自帶分頁!

    完!

    關于領域模型的補充說明:
    1:不管實體類的屬性如何命名哪怕是abcdef,只要配置好映射即:@Column注解對應的表字段。
    2:那么以上所述的查詢方式,仍然能正確返回結果,正確映射成Page<領域模型>。

    posted on 2017-11-14 14:20 朔望魔刃 閱讀(5678) 評論(0)  編輯  收藏 所屬分類: java
    主站蜘蛛池模板: 亚洲成a人片在线观看中文动漫| 久久精品夜色噜噜亚洲A∨| 久久久亚洲欧洲日产国码aⅴ| 岛国岛国免费V片在线观看| 亚洲欧洲一区二区三区| 日本特黄特色AAA大片免费| 日韩精品电影一区亚洲| 无码的免费不卡毛片视频| 亚洲啪啪AV无码片| a级毛片在线免费观看| 久久亚洲AV成人无码电影| 最近2018中文字幕免费视频| 亚洲午夜成激人情在线影院| 好大好硬好爽免费视频| 国产亚洲精品欧洲在线观看| 亚洲AV中文无码乱人伦| 国产拍拍拍无码视频免费| 亚洲精品无码久久毛片波多野吉衣 | 男人都懂www深夜免费网站| 久久青青草原亚洲AV无码麻豆| 99久久免费精品高清特色大片| 久久精品国产亚洲AV蜜臀色欲 | 国产AV无码专区亚洲AWWW| 暖暖免费在线中文日本| 亚洲理论在线观看| 暖暖日本免费在线视频| xxxxxx日本处大片免费看| 亚洲激情中文字幕| 四虎在线免费播放| 中文字幕无码免费久久9一区9| 精品无码一区二区三区亚洲桃色| 成人黄动漫画免费网站视频| 人人爽人人爽人人片A免费| 亚洲一级二级三级不卡| 最好免费观看韩国+日本| 本免费AV无码专区一区| 亚洲乱码卡三乱码新区| 亚洲男人av香蕉爽爽爽爽| 久久久免费精品re6| 国产精品亚洲天堂| 亚洲Av熟妇高潮30p|