<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 朔望魔刃 閱讀(5653) 評論(0)  編輯  收藏 所屬分類: java
    主站蜘蛛池模板: 美女视频黄a视频全免费网站一区| 国产成人精品日本亚洲语音| 免费无码黄十八禁网站在线观看| 亚洲日韩精品无码专区| 亚洲福利精品电影在线观看| 欧洲人成在线免费| 亚洲精品精华液一区二区| 亚洲乱码一区二区三区在线观看| 亚洲免费福利视频| 免费无遮挡无码视频在线观看 | 久久精品国产96精品亚洲| 四虎成人免费影院网址| 两性色午夜视频免费网| 亚洲一级毛片免费在线观看| 77777亚洲午夜久久多喷| 又色又污又黄无遮挡的免费视| 好久久免费视频高清| 亚洲色大18成人网站WWW在线播放| 国产亚洲成归v人片在线观看| 亚洲免费视频观看| 中文字幕av免费专区| 亚洲香蕉在线观看| 亚洲爆乳无码一区二区三区| 日本一道一区二区免费看| 日韩人妻无码精品久久免费一 | 99re免费视频| a毛片成人免费全部播放| 国产成人精品亚洲日本在线| 亚洲中文久久精品无码| 好吊妞998视频免费观看在线| 久久国产精品免费专区| 亚洲天堂免费在线视频| 亚洲乱码中文字幕在线| 亚洲日本在线看片| 亚洲一区无码中文字幕 | 亚洲影院在线观看| 久久精品国产亚洲7777| 国产在线ts人妖免费视频| 免费无码又爽又刺激聊天APP| 国产一区二区免费| 99精品免费视品|