spring-data-jpa原理探秘(2)-RepositoryQuery的用途和分类
為什么80%的碼農都做不了架構師?>>> ??
本系列的第二篇文章,主要講解在spring-data-jpa中占有重要地位的RepositoryQuery接口的用途和分類。
首先我們看看RepositoryQuery接口極其子類的類圖
上圖很清晰的說明,RepositoryQuery接口包含SimpleJpaQuery,NativeJpaQuery,PartTreeJpaQuery,NamedQuery,StoredProcedureJpaQuery等(葉子節點)子類。
JpaRepositoryFactory類在動態實例化Repository接口時,其父類RepositoryFactorySupport定義了一個私有Map類變量:
private final Map<Method, RepositoryQuery> queries = new ConcurrentHashMap<Method, RepositoryQuery>();而動態實例化Repository接口時,將實例化一個QueryExecutorMethodInterceptor,為其增加監聽和interceptor。上篇文章提到過,QueryExecutorMethodInterceptor是RepositoryFactorySupport的內部類,實現了org.aopalliance.intercept.MethodInterceptor攔截器接口。
實例化QueryExecutorMethodInterceptor時會直接執行其構造器,我們看到,給每個方法都創建了一個RepositoryQuery實例,并put到了上面所說的ConcurrentHashMap私有Map類變量中,代碼如下:
RepositoryQuery的直接抽象子類是AbstractJpaQuery,可以看到,一個RepositoryQuery實例持有一個JpaQueryMethod實例,JpaQueryMethod又持有一個Method實例,所以RepositoryQuery實例的用途很明顯,一個RepositoryQuery代表了Repository接口中的一個方法,根據方法頭上注解不同的形態,將每個Repository接口中的方法分別映射成相對應的RepositoryQuery實例。
下面我們就來看看spring-data-jpa對RepositoryQuery實例的具體分類:
1.SimpleJpaQuery
方法頭上@Query注解的nativeQuery屬性缺省值為false,也就是使用JPQL,此時會創建SimpleJpaQuery實例,并通過兩個StringQuery類實例分別持有query jpql語句和根據query jpql計算拼接出來的countQuery jpql語句;
2.NativeJpaQuery
方法頭上@Query注解的nativeQuery屬性如果顯式的設置為nativeQuery=true,也就是使用原生SQL,此時就會創建NativeJpaQuery實例;
3.PartTreeJpaQuery
方法頭上未進行@Query注解,將使用spring-data-jpa獨創的方法名識別的方式進行sql語句拼接,此時在spring-data-jpa內部就會創建一個PartTreeJpaQuery實例;
4.NamedQuery
使用javax.persistence.NamedQuery注解訪問數據庫的形式,此時在spring-data-jpa內部就會根據此注解選擇創建一個NamedQuery實例;
5.StoredProcedureJpaQuery
顧名思義,在Repository接口的方法頭上使用org.springframework.data.jpa.repository.query.Procedure注解,也就是調用存儲過程的方式訪問數據庫,此時在spring-data-jpa內部就會根據@Procedure注解而選擇創建一個StoredProcedureJpaQuery實例。
未完待續。
轉載于:https://my.oschina.net/ramboo/blog/815809
總結
以上是生活随笔為你收集整理的spring-data-jpa原理探秘(2)-RepositoryQuery的用途和分类的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Spring4.2+quartz2.2集
- 下一篇: [转载]敏捷开发之Scrum扫盲篇