小編這次要給大家分享的是詳解Spring Data JPA如何實(shí)現(xiàn)帶條件分頁(yè)查詢(xún),文章內(nèi)容豐富,感興趣的小伙伴可以來(lái)了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。
Spring Data JPA的Specification類(lèi), 是按照Eric Evans的《領(lǐng)域驅(qū)動(dòng)設(shè)計(jì)》書(shū)中Specification的概念和語(yǔ)義來(lái)定義查詢(xún)條件的API。
使用Spring Data JPA, 我們一般將自己的dao接口繼承CrudRepository接口和JpaSpecificationExecutor接口, 由框架生成代理類(lèi)來(lái)完成具體的調(diào)用, 而不用自己寫(xiě)daoImpl實(shí)現(xiàn)類(lèi), 因?yàn)檫@兩個(gè)接口自帶了很多方法, 如果我們寫(xiě)實(shí)現(xiàn)類(lèi)會(huì)發(fā)現(xiàn)一上來(lái)就需要實(shí)現(xiàn)十來(lái)個(gè)方法, 比較麻煩。
其中CrudRepository接口主要負(fù)責(zé)增/刪/改的操作, JpaSpecificationExecutor接口主要負(fù)責(zé)查詢(xún)的操作, 另外, 框架還支持在dao接口的方法名上定義一些簡(jiǎn)單的語(yǔ)義來(lái)進(jìn)行增刪改查, 底層會(huì)對(duì)應(yīng)地做具體實(shí)現(xiàn)。
那如何封裝具體的查詢(xún)條件呢?
在service層調(diào)用dao接口從JpaSpecificationExecutor繼承的抽象查詢(xún)方法, 它就會(huì)自動(dòng)讓你準(zhǔn)備相關(guān)實(shí)參, 其中Specification對(duì)象就是經(jīng)常用在條件查詢(xún)的方法的一個(gè)形參, 也就是說(shuō), 封裝查詢(xún)條件的過(guò)程轉(zhuǎn)移到service層了。
我們一般以匿名內(nèi)部類(lèi)的方式new一個(gè)Specification對(duì)象, 實(shí)現(xiàn)其中的toPredicate方法, 舉個(gè)例子,
Specification<Person> specification = new Specification<Person>() { @Override public Predicate toPredicate(Root<Person> root, CriteriaQuery<?> criteriaQuery, CriteriaBuilder criteriaBuilder) { ... };
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站vcdvsql.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性?xún)r(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專(zhuān)為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。
網(wǎng)頁(yè)題目:詳解SpringDataJPA如何實(shí)現(xiàn)帶條件分頁(yè)查詢(xún)-創(chuàng)新互聯(lián)
當(dāng)前URL:http://vcdvsql.cn/article34/csssse.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供響應(yīng)式網(wǎng)站、云服務(wù)器、網(wǎng)站內(nèi)鏈、營(yíng)銷(xiāo)型網(wǎng)站建設(shè)、建站公司、品牌網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容