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