MyBatis多對多一對多關(guān)系查詢嵌套處理
1. 數(shù)據(jù)準(zhǔn)備
數(shù)據(jù)庫
student 數(shù)據(jù)庫字段:
id int(10)
name varchar(30)
tid int(10)
teacher 數(shù)據(jù)庫字符:
id int(10)
name varchar(30)
實(shí)體類
Student:
@Data public class Student { private int id; private String name; private Teacher teacher; }
Teacher:
@Data public class Teacher { private int id; private String name; }
SQL語句
CREATE TABLE `teacher` ( `id` INT(10) NOT NULL, `name` VARCHAR(30) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=INNODB DEFAULT CHARSET=utf8 INSERT INTO teacher(`id`, `name`) VALUES (1, '秦老師'); CREATE TABLE `student` ( `id` INT(10) NOT NULL, `name` VARCHAR(30) DEFAULT NULL, `tid` INT(10) DEFAULT NULL, PRIMARY KEY (`id`), KEY `fktid` (`tid`), CONSTRAINT `fktid` FOREIGN KEY (`tid`) REFERENCES `teacher` (`id`) ) ENGINE=INNODB DEFAULT CHARSET=utf8 INSERT INTO `student` (`id`, `name`, `tid`) VALUES ('1', '小明', '1'); INSERT INTO `student` (`id`, `name`, `tid`) VALUES ('2', '小紅', '1'); INSERT INTO `student` (`id`, `name`, `tid`) VALUES ('3', '小張', '1'); INSERT INTO `student` (`id`, `name`, `tid`) VALUES ('4', '小李', '1'); INSERT INTO `student` (`id`, `name`, `tid`) VALUES ('5', '小王', '1');
實(shí)體接口
編寫實(shí)體類對應(yīng)的Mapper接口 【兩個(gè)】
public interface StudentMapper { } public interface TeacherMapper { }
mapper.xml
編寫Mapper接口對應(yīng)的 mapper.xml配置文件
StudentMapper.xml:
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.kuang.mapper.StudentMapper"> </mapper>
TeacherMapper.xml:
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.kuang.mapper.TeacherMapper"> </mapper>
2.一對多的關(guān)系
多個(gè)學(xué)生對應(yīng)一個(gè)老師.
2.1 按查詢嵌套處理
1、給StudentMapper接口增加方法:
//獲取所有學(xué)生及對應(yīng)老師的信息 public List<Student> getStudents();
- 編寫對應(yīng)的Mapper文件:
<mapper namespace="com.dao.StudentMapper"> <!-- 需求:獲取所有學(xué)生及對應(yīng)老師的信息 思路: 1. 獲取所有學(xué)生的信息 2. 根據(jù)獲取的學(xué)生信息的老師ID->獲取該老師的信息 3. 思考問題,這樣學(xué)生的結(jié)果集中應(yīng)該包含老師,該如何處理呢,數(shù)據(jù)庫中我們一般使用關(guān)聯(lián)查詢? 1. 做一個(gè)結(jié)果集映射:StudentTeacher 2. StudentTeacher結(jié)果集的類型為 Student 3. 學(xué)生中老師的屬性為teacher,對應(yīng)數(shù)據(jù)庫中為tid。 多個(gè) [1,...)學(xué)生關(guān)聯(lián)一個(gè)老師=> 一對一,一對多 4. 查看官網(wǎng)找到:association – 一個(gè)復(fù)雜類型的關(guān)聯(lián);使用它來處理關(guān)聯(lián)查詢 --> <select id="getStudents" resultMap="studentAllInfo" > select * from student </select> <resultMap id="studentAllInfo" type="com.pojo.Student"> <result column="id" property="id" /> <result column="name" property="name" /> <!--association關(guān)聯(lián)屬性 property屬性名 javaType屬性類型 column在多的一方的表中的列名--> <association property="teacher" column="tid" javaType="com.pojo.Teacher" select="getTeacher" /> </resultMap> <!-- 這里傳遞過來的id,只有一個(gè)屬性的時(shí)候,下面可以寫任何值 association中column多參數(shù)配置: column="{key=value,key=value}" 其實(shí)就是鍵值對的形式,key是傳給下個(gè)sql的取值名稱,value是片段一中sql查詢的字段名。 --> <select id="getTeacher" resultType="com.pojo.Teacher"> select * from teacher where id = #{tid} </select> </mapper>
2.2 按結(jié)果嵌套處理
- 接口方法編寫:
public List<Student> getStudents2();
- StudentMapper.xml:
<select id="getStudents2" resultMap="STInfo"> select s.id sid, s.name sname, t.id tid, t.name tname from student s, teacher t where s.tid = t.id </select> <resultMap id="STInfo" type="com.pojo.Student"> <result property="id" column="sid"/> <result property="name" column="sname" /> <association property="teacher" javaType="com.pojo.Teacher"> <result property="id" column="tid" /> <result property="name" column="tname" /> </association> </resultMap>
Test:
@Test public void testStudent01(){ SqlSession sqlsession = MyBatisUtils.getSqlSession(); StudentMapper studentMapper = sqlsession.getMapper(StudentMapper.class); List<Student> listStudent = studentMapper.getStudents2(); for (Student student : listStudent) { System.out.println(student); } }
3. 多對一的關(guān)系
一個(gè)老師對應(yīng)多個(gè)學(xué)生
數(shù)據(jù)準(zhǔn)備
Student
@Data public class Student { private int id; private String name; // private Teacher teacher; private int tid; }
Teacher
@Data public class Teacher { private int id; private String name; // 一個(gè)老師擁有多個(gè)學(xué)生 private List<Student> studentList; }
3.1 按結(jié)果嵌套處理
Mapper接口
TeacherMapper接口編寫方法:
//獲取指定老師,及老師下的所有學(xué)生 public Teacher getTeacher(int id);
編寫接口對應(yīng)的Mapper配置文件
<mapper namespace="com.dao.TeacherMapper"> <!-- 思路: 1. 從學(xué)生表和老師表中查出學(xué)生id,學(xué)生姓名,老師姓名 2. 對查詢出來的操作做結(jié)果集映射 * 集合的話,使用collection! * JavaType和ofType都是用來指定對象類型的 * JavaType是用來指定pojo中屬性的類型 * ofType指定的是映射到list集合屬性中pojo的類型。 --> <select id="getTeacher" resultMap="TeacherStuent" > select s.id sid, s.name sname, t.id tid, t.name tname from student s, teacher t where s.tid = t.id and t.id = #{tid} </select> <resultMap id="TeacherStuent" type="com.pojo.Teacher"> <result property="id" column="tid" /> <result property="name" column="tname" /> <!--集合的話,使用collection property : 對應(yīng)著 Teacher類中的屬性; javaType: 指定屬性的類型; 集合中的泛型,使用ofType獲取 !--> <collection property="studentList" ofType="com.pojo.Student"> <result property="id" column="sid" /> <result property="name" column="sname" /> <result property="tid" column="tid" /> </collection> </resultMap> </mapper>
Test:
@Test public void testgetTeacher(){ SqlSession sqlSession = MyBatisUtils.getSqlSession(); TeacherMapper teacherMapper = sqlSession.getMapper(TeacherMapper.class); Teacher teacher = teacherMapper.getTeacher(1); System.out.println( teacher ); sqlSession.close(); } }
3.2 按查詢嵌套處理
數(shù)據(jù)準(zhǔn)備
@Data public class Student { private int id; private String name; private int tid; } @Data public class Teacher { private int id; private String name; //一個(gè)老師多個(gè)學(xué)生 private List<Student> students; }
TeacherMapper接口編寫方法 :public Teacher getTeacher2(int id);
編寫接口對應(yīng)的Mapper配置文件
<mapper namespace="com.dao.TeacherMapper"> <select id="getTeacher2" resultMap="TeacherStuent"> select * from teacher where id = #{tid} </select> <resultMap id="TeacherStuent" type="com.pojo.Teacher"> <result property="id" column="id" /> <result property="name" column="name" /> <!--column是一對多的外鍵 , 寫的是一的主鍵的列名--> <collection property="studentList" javaType="ArrayList" ofType="com.pojo.Student" select="getStudentByTId" column="id"/> </resultMap> <select id="getStudentByTId" resultType="com.pojo.Student"> select * from student where tid = #{id} </select> </mapper>
Test:
@Test public void testgetTeacher2(){ SqlSession sqlSession = MyBatisUtils.getSqlSession(); TeacherMapper teacherMapper = sqlSession.getMapper(TeacherMapper.class); Teacher teacher = teacherMapper.getTeacher2(1); System.out.println(teacher); sqlSession.close(); }
以上就是MyBatis多對多一對多關(guān)系查詢嵌套處理的詳細(xì)內(nèi)容,更多關(guān)于MyBatis多對多一對多嵌套查詢的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
java數(shù)據(jù)結(jié)構(gòu)與算法數(shù)組模擬隊(duì)列示例詳解
這篇文章主要為大家介紹了java數(shù)據(jù)結(jié)構(gòu)與算法數(shù)組模擬隊(duì)列示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06springAop實(shí)現(xiàn)權(quán)限管理數(shù)據(jù)校驗(yàn)操作日志的場景分析
這篇文章主要介紹了springAop實(shí)現(xiàn)權(quán)限管理數(shù)據(jù)校驗(yàn)操作日志的場景分析,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-03-03Idea Jrebel 報(bào)錯(cuò):Cannot reactivate,offline 
本文主要介紹了Idea Jrebel 報(bào)錯(cuò):Cannot reactivate,offline seat in use,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06Java JTable 實(shí)現(xiàn)日歷的示例
這篇文章主要介紹了Java JTable 實(shí)現(xiàn)日歷的示例,幫助大家更好的理解和學(xué)習(xí)Java jtable的使用方法,感興趣的朋友可以了解下2020-10-10Struts2學(xué)習(xí)教程之入門小白的開始基礎(chǔ)
struts2其實(shí)就是為我們封裝了servlet,簡化了jsp跳轉(zhuǎn)的復(fù)雜操作,并且提供了易于編寫的標(biāo)簽,可以快速開發(fā)view層的代碼。下面這篇文章主要給各位想要學(xué)習(xí)Struts2的小白們詳細(xì)介紹了關(guān)于Struts2入門的一些開始基礎(chǔ),需要的朋友可以參考下2018-04-04Java中文件創(chuàng)建于寫入內(nèi)容的常見方法
在日常開發(fā)中,肯定離不開要和文件打交道,今天就簡單羅列一下平時(shí)比較常用的創(chuàng)建文件并向文件中寫入數(shù)據(jù)的幾種方式,希望對大家有一定的幫助2023-10-10springboot3 使用 jasypt 加密配置文件的使用步驟
在SpringBoot項(xiàng)目中,使用Jasypt加密配置文件可以有效保護(hù)敏感信息,首先,需添加Jasypt依賴并配置加密密碼,可在application.properties或通過啟動(dòng)參數(shù)、環(huán)境變量設(shè)置,本文介紹了Jasypt的配置步驟及使用方法,幫助開發(fā)者保護(hù)應(yīng)用配置信息2024-11-11