Jpa 聯(lián)表查詢

原文鏈接: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());
    }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容