使用SpringJPA?直接實現(xiàn)count(*)
SpringJPA 直接實現(xiàn)count(*)
剛開始使用JPA時,基本都依賴@query(SQL)注解通過原生sql來實現(xiàn)
根據(jù)編號統(tǒng)計條數(shù):
方法一
@Query(" select count(t) from FollowerInfo t where investUserId = :invUserId") Integer findFollowerNumberByInvUserId(@Param("invUserId") Long invUserId);
這種原生的方式,跟直接寫SQL沒什么區(qū)別。雖然能實現(xiàn)功能,但是浪費了JPA的簡潔簡化代碼的設計的優(yōu)點。
網(wǎng)上看到另外一個方法:
List findAll(Specification spec);
在repository層findAll,然后在service層封裝,獲取list.size()來處理總條數(shù)問題。
這樣避免了寫SQL語句。
今天看了一下CrudRepository的源碼 發(fā)現(xiàn)該接口源碼里面有一個函數(shù):
方法二
/** * Returns the number of entities available. * * @return the number of entities */ long count();
于是繼承了CrudRepository 寫了一個demo:
方法三
Long countByInvestUserId(Long investUserId);
一行代碼就全部搞定! 效果跟方法1一樣
(spring data jpa)jpa中使用count計數(shù)方法
spring data jpa中使用count計數(shù)方法很簡單
直接在dao層寫方法即可
int countByUidAndTenementId(String parentUid, String tenementId);
這樣即可根據(jù)傳入的字段查詢即可。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Java+opencv3.2.0實現(xiàn)人臉檢測功能
這篇文章主要為大家詳細介紹了Java+opencv3.2.0實現(xiàn)人臉檢測功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-02-02關于Java Spring三級緩存和循環(huán)依賴的深入理解
對于循環(huán)依賴,我相信讀者無論只是聽過也好,還是有過了解也好,至少都有所接觸。但是我發(fā)現(xiàn)目前許多博客對于循環(huán)依賴的講解并不清楚,都提到了Spring的循環(huán)依賴解決方案是三級緩存,但是三級緩存每一級的作用是什么,很多博客都沒有提到,本篇文章帶你深入了解2021-09-09