<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解決的事情,一定要幾條, 如何優(yōu)化成一條sql解決,還能帶上分頁?
    2:這個時候@Query注解里面的nativeQuery就可以派上用場 (用left join fetch也可以優(yōu)化成一條sql,見http://www.tkk7.com/liuguly/archive/2017/11/13/432890.html)
    3:nativeQuery的用途是可以使用原生sql。

    經(jīng)過實踐,官網(wǎng)給出的示例無法跑通:


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

        /**
         * 獲取喜歡的sharecare列表
         * 
    @param accountId 當(dāng)前用戶id
         * 
    @param fType 喜歡的類型  0-> sharecare  1-> babysitting  2->event
         * 
    @param pageable 分頁
         * 
    @return 分頁結(jié)果
         
    */
        @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表示查詢總數(shù)、nativeQuery表示這是一條原生sql

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

    經(jīng)過以上配置,就可正確查詢出結(jié)果且自帶分頁!

    完!

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

    posted on 2017-11-14 14:20 朔望魔刃 閱讀(5653) 評論(0)  編輯  收藏 所屬分類: java
    主站蜘蛛池模板: 永久黄网站色视频免费直播| 亚洲av日韩专区在线观看| 国产成人在线免费观看| 亚洲综合免费视频| 三年片在线观看免费西瓜视频| 亚洲AV无码之国产精品| 亚洲免费二区三区| 亚洲v高清理论电影| 久久综合亚洲色HEZYO国产| 蜜桃精品免费久久久久影院| 亚洲一区免费在线观看| 国产麻豆成人传媒免费观看| 大妹子影视剧在线观看全集免费| 国产精品亚洲二区在线| 亚洲一区二区三区丝袜| 亚洲精品亚洲人成在线播放| 亚洲精品视频在线观看免费| 久久精品国产亚洲av成人| 精品亚洲综合在线第一区| 亚洲综合国产精品第一页| 免费人成网站7777视频| 国产免费久久精品| 国产精品久免费的黄网站 | 亚洲乱码中文字幕综合| 亚洲av区一区二区三| 又粗又硬免费毛片| 国产精品免费电影| 免费中文字幕不卡视频| 少妇亚洲免费精品| 亚洲精品成a人在线观看| 亚洲免费一区二区| 国产成人亚洲综合无码| 在线A亚洲老鸭窝天堂| 中文字幕在线亚洲精品| 久久久久久久尹人综合网亚洲| 国产V亚洲V天堂A无码| 久久夜色精品国产嚕嚕亚洲av| 亚洲国语精品自产拍在线观看| 无码乱人伦一区二区亚洲一| 亚洲精品私拍国产福利在线| 亚洲黄色在线观看|