了解SpringDataJPA.docx_第1頁
了解SpringDataJPA.docx_第2頁
了解SpringDataJPA.docx_第3頁
了解SpringDataJPA.docx_第4頁
了解SpringDataJPA.docx_第5頁
已閱讀5頁,還剩2頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

了解SpringDataJPA前言自 JPA 伴隨 Java EE 5 發(fā)布以來,受到了各大廠商及開源社區(qū)的追捧,各種商用的和開源的 JPA 框架如雨后春筍般出現(xiàn),為開發(fā)者提供了豐富的選擇。它一改之前 EJB 2.x 中實(shí)體 Bean 笨重且難以使用的形象,充分吸收了在開源社區(qū)已經(jīng)相對成熟的 ORM 思想。另外,它并不依賴于 EJB 容器,可以作為一個(gè)獨(dú)立的持久層技術(shù)而存在。目前比較成熟的 JPA 框架主要包括 Jboss 的 Hibernate EntityManager、Oracle 捐獻(xiàn)給 Eclipse 社區(qū)的 EclipseLink、Apache 的 OpenJPA 等。Java持久化規(guī)范,是從EJB2.x以前的實(shí)體Bean(Entity bean)分離出來的,EJB3以后不再有實(shí)體bean,而是將實(shí)體bean放到JPA中實(shí)現(xiàn)。JPA是sun提出的一個(gè)對象持久化規(guī)范,各JavaEE應(yīng)用服務(wù)器自主選擇具體實(shí)現(xiàn),JPA的設(shè)計(jì)者是Hibernate框架的作者,因此Hibernate作為Jboss服務(wù)器中JPA的默認(rèn)實(shí)現(xiàn),Oracle的Weblogic使用EclipseLink(以前叫TopLink)作為默認(rèn)的JPA實(shí)現(xiàn),IBM的Websphere和Sun的Glassfish默認(rèn)使用OpenJPA(Apache的一個(gè)開源項(xiàng)目)作為其默認(rèn)的JPA實(shí)現(xiàn)。JPA的底層實(shí)現(xiàn)是一些流行的開源ORM(對象關(guān)系映射)框架,因此JPA其實(shí)也就是java實(shí)體對象和關(guān)系型數(shù)據(jù)庫建立起映射關(guān)系,通過面向?qū)ο缶幊痰乃枷氩僮麝P(guān)系型數(shù)據(jù)庫的規(guī)范。Spring 框架對 JPA 的支持Spring 框架對 JPA 提供的支持主要體現(xiàn)在如下幾個(gè)方面: 首先,它使得 JPA 配置變得更加靈活。JPA 規(guī)范要求,配置文件必須命名為 persistence.xml,并存在于類路徑下的 META-INF 目錄中。該文件通常包含了初始化 JPA 引擎所需的全部信息。Spring 提供的 LocalContainerEntityManagerFactoryBean 提供了非常靈活的配置,persistence.xml 中的信息都可以在此以屬性注入的方式提供。 其次,Spring 實(shí)現(xiàn)了部分在 EJB 容器環(huán)境下才具有的功能,比如對 PersistenceContext、PersistenceUnit 的容器注入支持。 第三,也是最具意義的,Spring 將 EntityManager 的創(chuàng)建與銷毀、事務(wù)管理等代碼抽取出來,并由其統(tǒng)一管理,開發(fā)者不需要關(guān)心這些,業(yè)務(wù)方法中只剩下操作領(lǐng)域?qū)ο蟮拇a,事務(wù)管理和 EntityManager 創(chuàng)建、銷毀的代碼都不再需要開發(fā)者關(guān)心了。Spring Data JPA更簡潔Spring Data JPA 框架,主要針對的就是 Spring 唯一沒有簡化到的業(yè)務(wù)邏輯代碼,至此,開發(fā)者連僅剩的實(shí)現(xiàn)持久層業(yè)務(wù)邏輯的工作都省了,唯一要做的,就只是聲明持久層的接口,其他都交給 Spring Data JPA 來幫你完成!下面就來了解Spring Data JPA。1.下載需要的包。需要先 下載Spring Data JPA 的發(fā)布包(需要同時(shí)下載 Spring Data Commons 和 Spring Data JPA 兩個(gè)發(fā)布包,Commons 是 Spring Data 的公共基礎(chǔ)包),并把相關(guān)的依賴 JAR 文件加入到 CLASSPATH 中。2.讓持久層接口 Dao(以UserDao)繼承 Repository 接口。該接口使用了泛型,需要為其提供兩個(gè)類型:第一個(gè)為該接口處理的域?qū)ο箢愋?,第二個(gè)為該域?qū)ο蟮闹麈I類型。 如下:Spring Data JPA 風(fēng)格的持久層接口:public interface UserDao extends Repository public AccountInfo save(AccountInfo accountInfo); 不需要UserDao的實(shí)現(xiàn)類,框架會(huì)為我們完成業(yè)務(wù)邏輯。3.在 Spring 配置文件中啟用掃描并自動(dòng)創(chuàng)建代理的功能。 - 需要在 標(biāo)簽中增加對 jpa 命名空間的引用 - 4.測試代碼。 public interface UserDao extends Repository public AccountInfo save(AccountInfo accountInfo); / 你需要做的,僅僅是新增如下一行方法聲明 public AccountInfo findByAccountId(Long accountId); 5.總結(jié)使用 Spring Data JPA 進(jìn)行持久層開發(fā)大致需要的三個(gè)步驟:1.聲明持久層的接口,該接口繼承 Repository,Repository 是一個(gè)標(biāo)記型接口,它不包含任何方法,當(dāng)然如果有需要,Spring Data 也提供了若干 Repository 子接口,其中定義了一些常用的增刪改查,以及分頁相關(guān)的方法。2.在接口中聲明需要的業(yè)務(wù)方法。Spring Data 將根據(jù)給定的策略來為其生成實(shí)現(xiàn)代碼。3.在 Spring 配置文件中增加一行聲明,讓 Spring 為聲明的接口創(chuàng)建代理對象。配置了 后,Spring 初始化容器時(shí)將會(huì)掃描 base-package 指定的包目錄及其子目錄,為繼承 Repository 或其子接口的接口創(chuàng)建代理對象,并將代理對象注冊為 Spring Bean,業(yè)務(wù)層便可以通過 Spring 自動(dòng)封裝的特性來直接使用該對象。此外, 還提供了一些屬性和子標(biāo)簽,便于做更細(xì)粒度的控制??梢栽?內(nèi)部使用 、 來過濾掉一些不希望被掃描到的接口。接口繼承持久層接口繼承 Repository 并不是唯一選擇。Repository 接口是 Spring Data 的一個(gè)核心接口,它不提供任何方法,開發(fā)者需要在自己定義的接口中聲明需要的方法。與繼承 Repository 等價(jià)的一種方式,就是在持久層接口上使用 RepositoryDefinition 注解,并為其指定 domainClass 和 idClass 屬性。如下兩種方式是完全等價(jià)的:兩種等價(jià)的繼承接口方式示例:public interface UserDao extends Repository RepositoryDefinition(domainClass = AccountInfo.class, idClass = Long.class) public interface UserDao 1.如果持久層接口較多,且每一個(gè)接口都需要聲明相似的增刪改查方法,直接繼承 Repository 就顯得有些啰嗦,這時(shí)可以繼承 CrudRepository,它會(huì)自動(dòng)為域?qū)ο髣?chuàng)建增刪改查方法,供業(yè)務(wù)層直接使用。開發(fā)者只是多寫了 Crud 四個(gè)字母,即刻便為域?qū)ο筇峁┝碎_箱即用的十個(gè)增刪改查方法。2.使用 CrudRepository 也有副作用,它可能暴露了你不希望暴露給業(yè)務(wù)層的方法。比如某些接口你只希望提供增加的操作而不希望提供刪除的方法。針對這種情況,開發(fā)者只能退回到 Repository 接口,然后到 CrudRepository 中把希望保留的方法聲明復(fù)制到自定義的接口中即可.3.分頁查詢和排序是持久層常用的功能,Spring Data 為此提供了 PagingAndSortingRepository 接口,它繼承自 CrudRepository 接口,在 CrudRepository 基礎(chǔ)上新增了兩個(gè)與分頁有關(guān)的方法。但是,我們很少會(huì)將自定義的持久層接口直接繼承自 PagingAndSortingRepository,而是在繼承 Repository 或 CrudRepository 的基礎(chǔ)上,在自己聲明的方法參數(shù)列表最后增加一個(gè) Pageable 或 Sort 類型的參數(shù),用于指定分頁或排序信息即可,這比直接使用 PagingAndSortingRepository 提供了更大的靈活性。4.JpaRepository 是繼承自 PagingAndSortingRepository 的針對 JPA 技術(shù)提供的接口,它在父接口的基礎(chǔ)上,提供了其他一些方法,比如 flush(),saveAndFlush(),deleteInBatch() 等。如果有這樣的需求,則可以繼承該接口。查詢方式1.通過解析方法名創(chuàng)建查詢框架在進(jìn)行方法名解析時(shí),會(huì)先把方法名多余的前綴截取掉,比如 find、findBy、read、readBy、get、getBy,然后對剩下部分進(jìn)行解析。并且如果方法的最后一個(gè)參數(shù)是 Sort 或者 Pageable 類型,也會(huì)提取相關(guān)的信息,以便按規(guī)則進(jìn)行排序或者分頁查詢。在創(chuàng)建查詢時(shí),我們通過在方法名中使用屬性名稱來表達(dá),比如 findByUserAddressZip ()??蚣茉诮馕鲈摲椒〞r(shí),首先剔除 findBy,然后對剩下的屬性進(jìn)行解析,詳細(xì)規(guī)則如下(此處假設(shè)該方法針對的域?qū)ο鬄?AccountInfo 類型): 先判斷 userAddressZip (根據(jù) POJO 規(guī)范,首字母變?yōu)樾?,下同)是否?AccountInfo 的一個(gè)屬性,如果是,則表示根據(jù)該屬性進(jìn)行查詢;如果沒有該屬性,繼續(xù)第二步; 從右往左截取第一個(gè)大寫字母開頭的字符串(此處為 Zip),然后檢查剩下的字符串是否為 AccountInfo 的一個(gè)屬性,如果是,則表示根據(jù)該屬性進(jìn)行查詢;如果沒有該屬性,則重復(fù)第二步,繼續(xù)從右往左截取;最后假設(shè) user 為 AccountInfo 的一個(gè)屬性; 接著處理剩下部分( AddressZip ),先判斷 user 所對應(yīng)的類型是否有 addressZip 屬性,如果有,則表示該方法最終是根據(jù) AccountInfo.user.addressZip 的取值進(jìn)行查詢;否則繼續(xù)按照步驟 2 的規(guī)則從右往左截取,最終表示根據(jù) AccountInfo.user.address.zip 的值進(jìn)行查詢。在查詢時(shí),通常需要同時(shí)根據(jù)多個(gè)屬性進(jìn)行查詢,且查詢的條件也格式各樣(大于某個(gè)值、在某個(gè)范圍等等),Spring Data JPA 為此提供了一些表達(dá)條件查詢的關(guān)鍵字,大致如下: And - 等價(jià)于 SQL 中的 and 關(guān)鍵字,比如 findByUsernameAndPassword(String user, Striang pwd); Or - 等價(jià)于 SQL 中的 or 關(guān)鍵字,比如 findByUsernameOrAddress(String user, String addr); Between - 等價(jià)于 SQL 中的 between 關(guān)鍵字,比如 findBySalaryBetween(int max, int min); LessThan - 等價(jià)于 SQL 中的 ,比如 findBySalaryGreaterThan(int min); IsNull - 等價(jià)于 SQL 中的 is null,比如 findByUsernameIsNull(); IsNotNull - 等價(jià)于 SQL 中的 is not null,比如 findByUsernameIsNotNull(); NotNull - 與 IsNotNull 等價(jià); Like - 等價(jià)于 SQL 中的 like,比如 findByUsernameLike(String user); NotLike - 等價(jià)于 SQL 中的 not like,比如 findByUsernameNotLike(String user); OrderBy - 等價(jià)于 SQL 中的 order by,比如 findByUsernameOrderBySalaryAsc(String user); Not - 等價(jià)于 SQL 中的 ! =,比如 findByUsernameNot(String user); In - 等價(jià)于 SQL 中的 in,比如 findByUsernameIn(Collection userList) ,方法的參數(shù)可以是 Collection 類型,也可以是數(shù)組或者不定長參數(shù); NotIn - 等價(jià)于 SQL 中的 not in,比如 findByUsernameNotIn(Collection userList) ,方法的參數(shù)可以是 Collection 類型,也可以是數(shù)組或者不定長參數(shù);2.使用 Query 創(chuàng)建查詢Query 注解的使用非常簡單,只需在聲明的方法上面標(biāo)注該注解,同時(shí)提供一個(gè) JP QL 查詢語句即可,如下所示: public interface UserDao extends Repository Query(select a from AccountInfo a where a.accountId = ?1) public AccountInfo findByAccountId(Long accountId); Query(select a from AccountInfo a where a.balance ?1) public Page findByBalanceGreaterThan( Integer balance,Pageable pageable); 很多開發(fā)者在創(chuàng)建 JP QL 時(shí)喜歡使用命名參數(shù)來代替位置編號(hào),Query 也對此提供了支持。JP QL 語句中通過: 變量的格式來指定參數(shù),同時(shí)在方法的參數(shù)前面使用 Param 將方法參數(shù)與 JP QL 中的命名參數(shù)對應(yīng),示例如下:public interface UserDao extends Repository public AccountInfo save(AccountInfo accountInfo); Query(from AccountInfo a where a.accountId = :id) public AccountInfo findByAccountId(Param(id)Long accountId); Query(from AccountInfo a where a.balance :balance) public Page findByBalanceGreaterThan( Param(balance)Integer balance,Pageable pageable); 此外,開發(fā)者也可以通過使用 Query 來執(zhí)行一個(gè)更新操作,為此,我們需要在使用 Query 的同時(shí),用 Modifying 來將該操作標(biāo)識(shí)為修改查詢,這樣框架最終會(huì)生成一個(gè)更新的操作,而非查詢。如下所示: Modifying Query(update AccountInfo a set a.salary = ?1 where a.salary ?2) public int increaseSalary(int after, int before); 3.通過調(diào)用 JPA 命名查詢語句創(chuàng)建查詢命名查詢是 JPA 提供的一種將查詢語句從方法體中獨(dú)立出來,以供多個(gè)方法共用的功能。Spring Data JPA 對命名查詢也提供了很好的支持。用戶只需要按照 JPA 規(guī)范在 orm.xml 文件或者在代碼中使用 Nam

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論