擴(kuò)展repository ,增加一些自定義的接口
一、定義Repository接口
package com.demo.dao;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.NoRepositoryBean;
import java.io.Serializable;
@NoRepositoryBean
public interface BaseRepository<T, ID extends Serializable> extends JpaRepository<T,ID> {
@Query("select r from #{#entityName} r where r.id=?1 and r.ratingRequestId=?2")
T findOne(Integer id, Long ratingRequestId);
@Deprecated
T findOne(ID var1);
}
注意 : 要加上
@NoRepositoryBean, 因?yàn)檫@里使用了泛型,@Query("select r from #{#entityName} r where r.id=?1 and r.ratingRequestId=?2")使用SpEL表達(dá)式#{#entityName}代表實(shí)體名
二、繼承Repository接口
package com.demo.dao;
import org.springframework.stereotype.Repository;
import org.springframework.transaction.annotation.Transactional;
import com.demo.dao.BaseRepository;
import com.demo.domain.ApiRecordOfflineDO;
@Repository
@Transactional
public interface ApiRecordOfflineDAO extends BaseRepository<ApiRecordOfflineDO, Integer> {
// 其它方法
}
二、使用Repository接口
@Autowired
private ApiRecordOfflineDAO apiRecordDAO;
// 這里注入后,就可以調(diào)用findOne(Integer id, Long ratingRequestId)
以上只是擴(kuò)展接口,沒有自己去實(shí)現(xiàn)這個(gè)findOne方法 , 如果要自己實(shí)現(xiàn)具體查詢過程,看這里 Spring技術(shù)內(nèi)幕之Spring Data JPA-自定義Repository實(shí)現(xiàn)