MyBatis圖文并茂講解注解開發(fā)一對多查詢
MyBatis的注解實現(xiàn)復雜映射開發(fā)
實現(xiàn)復雜關系映射之前我們可以在映射文件中通過配置來實現(xiàn),使用注解開發(fā)后,我們可以使用@Results注解,@Result注解,@One注解,@Many注解組合完成復雜關系的配置


一對多查詢
一對多查詢的模型
一對多查詢的需求:查詢一個課程,與此同時查詢出該該課程對應的學生信息

一對多查詢的語句
對應的sql語句:
SELECT * FROM classes
SELECT * FROM student WHERE cid=#{cid}創(chuàng)建StudentMapper接口
public interface StudentMapper {
//根據cid查詢student表
@Select("SELECT * FROM student WHERE cid=#{cid}")
public abstract List<Student> selectByCid(Integer cid);
}使用注解配置Mapper
public interface ClassesMapper {
//查詢全部
@Select("SELECT * FROM classes")
@Results({
@Result(column = "id",property = "id"),
@Result(column = "name",property = "name"),
@Result(
property = "students", // 被包含對象的變量名
javaType = List.class, // 被包含對象的實際數(shù)據類型
column = "id", // 根據查詢出的classes表的id字段來查詢student表
/*
many、@Many 一對多查詢的固定寫法
select屬性:指定調用哪個接口中的哪個查詢方法
*/
many = @Many(select = "com.yyl.one_to_many.StudentMapper.selectByCid")
)
})
public abstract List<Classes> selectAll();
}測試類
public class Test01 {
@Test
public void selectAll() throws Exception{
//1.加載核心配置文件
InputStream is = Resources.getResourceAsStream("MyBatisConfig.xml");
//2.獲取SqlSession工廠對象
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
//3.通過工廠對象獲取SqlSession對象
SqlSession sqlSession = sqlSessionFactory.openSession(true);
//4.獲取ClassesMapper接口的實現(xiàn)類對象
ClassesMapper mapper = sqlSession.getMapper(ClassesMapper.class);
//5.調用實現(xiàn)類對象中的方法,接收結果
List<Classes> list = mapper.selectAll();
//6.處理結果
for (Classes cls : list) {
System.out.println(cls.getId() + "," + cls.getName());
List<Student> students = cls.getStudents();
for (Student student : students) {
System.out.println("\t" + student);
}
}
//7.釋放資源
sqlSession.close();
is.close();
}
}運行結果如下:

一對多配置總結
| 注解 | 說明 |
|---|---|
| @Results | 封裝映射關系的父注解。 Result[] value():定義了 Result 數(shù)組 |
| @Result | 封裝映射關系的子注解。 column 屬性:查詢出的表中字段名稱 property 屬性:實體對象中的屬性名稱 javaType 屬性:被包含對象的數(shù)據類型 many 屬性:一對多查詢固定屬性 |
| @Many | 一對多查詢的注解。 select 屬性:指定調用某個接口中的方法 |
到此這篇關于MyBatis圖文并茂講解注解開發(fā)一對多查詢的文章就介紹到這了,更多相關MyBatis一對多查詢內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
解讀Eureka的TimedSupervisorTask類(自動調節(jié)間隔的周期性任務)
在Eureka客戶端中,盡管ScheduledExecutorService的schedule方法創(chuàng)建的是一次性任務,但通過在任務執(zhí)行完畢后再次調用schedule方法實現(xiàn)了周期性執(zhí)行,這種設計既考慮到了任務超時導致的間隔時間調整,又通過CAS實現(xiàn)了多線程同步,展現(xiàn)了簡潔而巧妙的設計思想2024-11-11
淺談圖片上傳利用request.getInputStream()獲取文件流時遇到的問題
下面小編就為大家?guī)硪黄獪\談圖片上傳利用request.getInputStream()獲取文件流時遇到的問題。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-11-11
SpringSecurity從數(shù)據庫中獲取用戶信息進行驗證的案例詳解
這篇文章主要介紹了SpringSecurity從數(shù)據庫中獲取用戶信息進行驗證的案例詳解,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-01-01
Spring使用@Filter注解創(chuàng)建自定義過濾器
Spring 中鮮為人知但非常有用的注解之一是 @Filter,它支持自定義過濾器,下面我們就來深入研究一下如何使用 Spring 的 @Filter 注解來創(chuàng)建自定義過濾器吧2023-11-11
關于SpringSecurity配置403權限訪問頁面的完整代碼
本文給大家分享SpringSecurity配置403權限訪問頁面的完整代碼,配置之前和配置之后的詳細介紹,代碼簡單易懂,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧2021-06-06
MyBatis-Plus輸出完整SQL(帶參數(shù))的三種方案
當我們使用 mybatis-plus 時,可能會遇到SQL 不能直接執(zhí)行,調試也不方便的情況,那么,如何打印完整 SQL(帶參數(shù))呢?本篇文章將介紹 3 種實現(xiàn)方式,并對比它們的優(yōu)缺點,需要的朋友可以參考下2025-02-02

