原文鏈接:https://blog.csdn.net/qq_40693828/article/details/95357975
眾所周知,Spring Boot Jpa 是 Spring 基于 ORM 框架、Jpa 規(guī)范的基礎(chǔ)上封裝的一套 Jpa 應(yīng)用框架,可使開發(fā)者用極簡的代碼即可實(shí)現(xiàn)對(duì)數(shù)據(jù)的訪問和操作。它提供了包括增刪改查等在內(nèi)的常用功能,且易于擴(kuò)展!學(xué)習(xí)并使用 Spring Data Jpa 可以極大提高開發(fā)效率。
public interface UserJPA extends JpaRepository<UserEntity, String>, JpaSpecificationExecutor<UserEntity>, Serializable {
//關(guān)聯(lián)查詢 @Query可以用于自定義sql語句,如果是修改需加上@Modifying ,這是一條關(guān)聯(lián)查詢語句,返回的結(jié)果映射到新對(duì)象中,新對(duì)象為接口,里面含有對(duì)應(yīng)參數(shù)的構(gòu)造方法。
@Query(value="select u.username,p.id,p.title from user u join page p on u.id = p.user where u.username = ?1",nativeQuery = true)
List<UserPageDao> find(String username);
}
其中,nativeQuery 語句中的 select 后面的參數(shù) 到from前面的參數(shù),要與下面的類的屬性值一一對(duì)應(yīng)
public interface UserPageDao {
String getUsername();
Long getId();
String getTitle();
}
使用方法
@Test
void userPageTest(){
List<UserPageDao> viewInfos = userJPA.find("username");
for (UserPageDao viewInfo : viewInfos) {
System.out.println("pageId:"+viewInfo.getId()+" pageTitle:"+viewInfo.getTitle()+" userName"+viewInfo.getUsername());
}
}