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

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

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

    paulwong

    讓spring-data-jpa解放你的DAO

    最近項目用Spring-data-jpa,確實很方便。如果你也曾經被重復無聊的dao代碼雷到的話,就可以考慮將ORM framework換成spring-data-jpa了。 只要繼承CrudRepository或者PagingAndSortingRepository,dao層基本上就只剩下定義接口方法這么一件事情了,連實現都不用寫,因為默認實現SimpleJpaRepository已經幫你實現了基本的CRUD,是不是很方便?基本的CRUD就全解決了。

    廢話少說,上代碼:

    1@NoRepositoryBean
    2public interface BaseRepository<T, ID extends Serializable> extends CrudRepository<T, ID>{
    3 
    4}
    5 
    6@Transational
    7public interface TestRepository extends BaseRepository<Test,Long>{
    8    Test findByName(String name);
    9}

    只需這么定義,然后testRepository對象就天然擁有CRUD的方法,它會動態將findByName()的方法定義翻譯成適當的HQL。

    01@Transational
    02public class TestServiceImpl{
    03    @Autowried
    04    private TestRepository testRepository;
    05    public void test(){
    06        testRepository.findOne(id);
    07        testRepository.findAll(ids);
    08        testRepository.delete(id);
    09        testRepository.findByName(name);
    10    }
    11}

    各種翻譯規則可細看官方文檔

    而且還可以用@Query的注解。在方法中寫JPQL查詢語句,還支持nativeQuery,可以使用原生SQL,對報表之類對性能要求比較高的查詢就很給力了。

    如果有時候只是想查詢實體中的某幾個字段,而不是整張表都查詢出來,可以采用以下方法

    1@Transactional
    2public interface TestRepository extends BaseRepository<Test,Long>{
    3 
    4    @Query("select t.id, t.name from Test t")
    5    public List<Object[]> findSimpleTest()
    6}

    然后在調用該repository的service中遍歷將對應的字段轉換為相應的字段即可。

    具體可以看官方reference

    如果SimpleJpaRepository中的方法不夠用,擴展起來也非常方便,只要在BaseRepository定義自己的借口方法,然后實現類繼承SimpleJpaRepository實現自己的方法,然后將jpa的factory-class替換成自己寫的實現類即可。

    當然spring data jpa也有criteria實現,叫Specification,有自己的語法,就一個接口方法,多表關聯復雜條件查詢很多時候就需要用到這個,還沒細研究。再議。

    posted on 2013-05-09 14:16 paulwong 閱讀(5571) 評論(1)  編輯  收藏 所屬分類: SPRING

    Feedback

    # re: 讓spring-data-jpa解放你的DAO 2015-07-02 17:39 zuidaima

    springdata demo教程源代碼下載:http://zuidaima.com/share/kspringdata-p1-s1.htm  回復  更多評論   


    主站蜘蛛池模板: 九九精品免费视频| 在线观看片免费人成视频播放| 美女视频黄a视频全免费网站色窝| 日韩免费一区二区三区| 中文字幕亚洲情99在线| 在线jlzzjlzz免费播放| 亚洲乱码av中文一区二区| 国产情侣激情在线视频免费看| 亚洲综合免费视频| **毛片免费观看久久精品| 亚洲另类春色国产精品| xx视频在线永久免费观看| 亚洲午夜一区二区电影院| 日本免费网址大全在线观看| 亚洲偷偷自拍高清| 精品国产免费观看一区| 色欲aⅴ亚洲情无码AV蜜桃| 全黄a免费一级毛片人人爱| 一级毛片免费播放视频| 亚洲一区二区三区偷拍女厕 | 大胆亚洲人体视频| 四虎国产精品永免费| 亚洲午夜久久久久久久久久 | 亚洲乱码无限2021芒果| 免费a级毛片高清视频不卡| 亚洲av无码兔费综合| 亚洲性日韩精品一区二区三区 | 日韩成人免费视频| 亚洲国产成人超福利久久精品| 成人激情免费视频| 亚洲AV永久无码精品网站在线观看 | 中文字幕亚洲综合久久2| 日本妇人成熟免费中文字幕| 看成年女人免费午夜视频| 在线观看午夜亚洲一区| 在线免费中文字幕| 天天综合亚洲色在线精品| 国产亚洲精品观看91在线| 18禁无遮挡无码网站免费| av电影在线免费看| 亚洲国产午夜精品理论片|