亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MyBatis多對(duì)多一對(duì)多關(guān)系查詢嵌套處理

 更新時(shí)間:2023年10月15日 12:05:48   作者:phang  
這篇文章主要為大家介紹了MyBatis多對(duì)多一對(duì)多關(guān)系查詢嵌套處理示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

1. 數(shù)據(jù)準(zhǔn)備

數(shù)據(jù)庫(kù)

student 數(shù)據(jù)庫(kù)字段:

id int(10)

name varchar(30)

tid int(10)

teacher 數(shù)據(jù)庫(kù)字符:

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語(yǔ)句

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í)體接口

編寫(xiě)實(shí)體類對(duì)應(yīng)的Mapper接口 【兩個(gè)】

public interface StudentMapper {
}
public interface TeacherMapper {
}

mapper.xml

編寫(xiě)Mapper接口對(duì)應(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.一對(duì)多的關(guān)系

多個(gè)學(xué)生對(duì)應(yīng)一個(gè)老師.

2.1 按查詢嵌套處理

1、給StudentMapper接口增加方法:

//獲取所有學(xué)生及對(duì)應(yīng)老師的信息
public List<Student> getStudents();
  • 編寫(xiě)對(duì)應(yīng)的Mapper文件:
<mapper namespace="com.dao.StudentMapper">
<!--
   需求:獲取所有學(xué)生及對(duì)應(yīng)老師的信息
   思路:
       1. 獲取所有學(xué)生的信息
       2. 根據(jù)獲取的學(xué)生信息的老師ID->獲取該老師的信息
       3. 思考問(wèn)題,這樣學(xué)生的結(jié)果集中應(yīng)該包含老師,該如何處理呢,數(shù)據(jù)庫(kù)中我們一般使用關(guān)聯(lián)查詢?
           1. 做一個(gè)結(jié)果集映射:StudentTeacher
           2. StudentTeacher結(jié)果集的類型為 Student
           3. 學(xué)生中老師的屬性為teacher,對(duì)應(yīng)數(shù)據(jù)庫(kù)中為tid。
              多個(gè) [1,...)學(xué)生關(guān)聯(lián)一個(gè)老師=> 一對(duì)一,一對(duì)多
           4. 查看官網(wǎng)找到:association – 一個(gè)復(fù)雜類型的關(guān)聯(lián);使用它來(lái)處理關(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>
 <!--
   這里傳遞過(guò)來(lái)的id,只有一個(gè)屬性的時(shí)候,下面可以寫(xiě)任何值
   association中column多參數(shù)配置:
       column="{key=value,key=value}"
       其實(shí)就是鍵值對(duì)的形式,key是傳給下個(gè)sql的取值名稱,value是片段一中sql查詢的字段名。
   -->
        <select id="getTeacher" resultType="com.pojo.Teacher">
        select * from teacher where id = #{tid}
    </select>
</mapper>

2.2 按結(jié)果嵌套處理

  • 接口方法編寫(xiě):
    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&lt;Student&gt; listStudent = studentMapper.getStudents2();
        for (Student student : listStudent) {
            System.out.println(student);
        }
    }

3. 多對(duì)一的關(guān)系

一個(gè)老師對(duì)應(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&lt;Student&gt; studentList;
}

3.1 按結(jié)果嵌套處理

Mapper接口

TeacherMapper接口編寫(xiě)方法:

//獲取指定老師,及老師下的所有學(xué)生
public Teacher getTeacher(int id);

編寫(xiě)接口對(duì)應(yīng)的Mapper配置文件

<mapper namespace="com.dao.TeacherMapper">
   <!--
   思路:
       1. 從學(xué)生表和老師表中查出學(xué)生id,學(xué)生姓名,老師姓名
       2. 對(duì)查詢出來(lái)的操作做結(jié)果集映射
          * 集合的話,使用collection!
          * JavaType和ofType都是用來(lái)指定對(duì)象類型的
          * JavaType是用來(lái)指定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 : 對(duì)應(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&lt;Student&gt; students;
}

TeacherMapper接口編寫(xiě)方法 :public Teacher getTeacher2(int id);

編寫(xiě)接口對(duì)應(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是一對(duì)多的外鍵 , 寫(xiě)的是一的主鍵的列名-->
        <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多對(duì)多一對(duì)多關(guān)系查詢嵌套處理的詳細(xì)內(nèi)容,更多關(guān)于MyBatis多對(duì)多一對(duì)多嵌套查詢的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • java數(shù)據(jù)結(jié)構(gòu)與算法數(shù)組模擬隊(duì)列示例詳解

    java數(shù)據(jù)結(jié)構(gòu)與算法數(shù)組模擬隊(duì)列示例詳解

    這篇文章主要為大家介紹了java數(shù)據(jù)結(jié)構(gòu)與算法數(shù)組模擬隊(duì)列示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-06-06
  • springAop實(shí)現(xiàn)權(quán)限管理數(shù)據(jù)校驗(yàn)操作日志的場(chǎng)景分析

    springAop實(shí)現(xiàn)權(quán)限管理數(shù)據(jù)校驗(yàn)操作日志的場(chǎng)景分析

    這篇文章主要介紹了springAop實(shí)現(xiàn)權(quán)限管理數(shù)據(jù)校驗(yàn)操作日志的場(chǎng)景分析,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-03-03
  • Idea Jrebel 報(bào)錯(cuò):Cannot reactivate,offline seat in use

    Idea Jrebel 報(bào)錯(cuò):Cannot reactivate,offline 

    本文主要介紹了Idea Jrebel 報(bào)錯(cuò):Cannot reactivate,offline seat in use,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • Java JTable 實(shí)現(xiàn)日歷的示例

    Java JTable 實(shí)現(xiàn)日歷的示例

    這篇文章主要介紹了Java JTable 實(shí)現(xiàn)日歷的示例,幫助大家更好的理解和學(xué)習(xí)Java jtable的使用方法,感興趣的朋友可以了解下
    2020-10-10
  • Struts2學(xué)習(xí)教程之入門(mén)小白的開(kāi)始基礎(chǔ)

    Struts2學(xué)習(xí)教程之入門(mén)小白的開(kāi)始基礎(chǔ)

    struts2其實(shí)就是為我們封裝了servlet,簡(jiǎn)化了jsp跳轉(zhuǎn)的復(fù)雜操作,并且提供了易于編寫(xiě)的標(biāo)簽,可以快速開(kāi)發(fā)view層的代碼。下面這篇文章主要給各位想要學(xué)習(xí)Struts2的小白們?cè)敿?xì)介紹了關(guān)于Struts2入門(mén)的一些開(kāi)始基礎(chǔ),需要的朋友可以參考下
    2018-04-04
  • Java中文件創(chuàng)建于寫(xiě)入內(nèi)容的常見(jiàn)方法

    Java中文件創(chuàng)建于寫(xiě)入內(nèi)容的常見(jiàn)方法

    在日常開(kāi)發(fā)中,肯定離不開(kāi)要和文件打交道,今天就簡(jiǎn)單羅列一下平時(shí)比較常用的創(chuàng)建文件并向文件中寫(xiě)入數(shù)據(jù)的幾種方式,希望對(duì)大家有一定的幫助
    2023-10-10
  • springboot3 使用 jasypt 加密配置文件的使用步驟

    springboot3 使用 jasypt 加密配置文件的使用步驟

    在SpringBoot項(xiàng)目中,使用Jasypt加密配置文件可以有效保護(hù)敏感信息,首先,需添加Jasypt依賴并配置加密密碼,可在application.properties或通過(guò)啟動(dòng)參數(shù)、環(huán)境變量設(shè)置,本文介紹了Jasypt的配置步驟及使用方法,幫助開(kāi)發(fā)者保護(hù)應(yīng)用配置信息
    2024-11-11
  • 面試JAVA時(shí),問(wèn)到spring該怎么回答

    面試JAVA時(shí),問(wèn)到spring該怎么回答

    這篇文章主要介紹了Spring面試資料,學(xué)Java的小伙伴都知道Spring是面試的必問(wèn)環(huán)節(jié),看完了一天就可掌握數(shù)據(jù)結(jié)構(gòu)和算法的面試題,快來(lái)看看吧
    2021-08-08
  • 利用Java編寫(xiě)一個(gè)出敬業(yè)福的小程序

    利用Java編寫(xiě)一個(gè)出敬業(yè)福的小程序

    新年將至,又開(kāi)始掃?;顒?dòng),每年的敬業(yè)福成了大家難過(guò)的坎。所以本文將介紹一個(gè)通過(guò)Java編寫(xiě)的一款福字生成器,感興趣的小伙伴可以試一試
    2022-01-01
  • 深入分析JAVA Vector和Stack的具體用法

    深入分析JAVA Vector和Stack的具體用法

    這篇文章主要介紹了深入分析JAVA Vector和Stack的具體用法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-12-12

最新評(píng)論