java企业级信息系统开发学习笔记10 利用MyBatis实现关联查询

news2025/1/12 12:31:19

文章目录

  • 一、学习目标
    • (一)针对三张表关联查询
    • (二)按班级编号查询班级信息
    • (三)查询全部班级信息
  • 二、创建数据库
    • (一)创建教师表
    • (二)创建班级表
    • (三)创建学生表
  • 三、创建与数据库表对应的实体类
    • (一)创建教师实体类
    • (二)创建学生实体类
    • (三)创建班级实体类
  • 四、创建班级映射器配置文件
  • 五、修改mybatis配置文件
  • 六、创建班级映射器接口
  • 七、创建班级映射器测试类
    • (一)测试按编号查询班级方法
    • (二)测试查询全部班级方法

一、学习目标

  • 掌握利用MyBatis实现关联查询

(一)针对三张表关联查询

  • 一个班级配置一个教师,一个班级有多个学生

(二)按班级编号查询班级信息

  • 要求查询到的班级带老师信息和该班学生信息

(三)查询全部班级信息

  • 要求查询的班级信息只带老师的信息,不带学生信息

二、创建数据库

(一)创建教师表

  • 执行SQL语句,创建教师表t_teacher
CREATE TABLE `t_teacher` (
`t_id` int(11) NOT NULL AUTO_INCREMENT,
`t_name` varchar(20) DEFAULT NULL,
PRIMARY KEY (`t_id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8mb4;

  • 执行SQL语句,插入3条记录
INSERT INTO `t_teacher` VALUES ('1', '刘晓云');
INSERT INTO `t_teacher` VALUES ('2', '郑同华');
INSERT INTO `t_teacher` VALUES ('3', '李明军');

在这里插入图片描述

(二)创建班级表

  • 执行SQL语句,创建班级表t_class
CREATE TABLE `t_class` (
  `c_id` int(11) NOT NULL AUTO_INCREMENT,
  `c_name` varchar(20) DEFAULT NULL,
  `teacher_id` int(11) DEFAULT NULL,
PRIMARY KEY (`c_id`),
KEY `fk_teacher_id` (`teacher_id`),
CONSTRAINT `fk_teacher_id` FOREIGN KEY (`teacher_id`) REFERENCES `t_teacher` (`t_id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8mb4;

  • 执行SQL语句,插入3条记录
INSERT INTO `t_class` VALUES ('1', '2021软件1班', '3');
INSERT INTO `t_class` VALUES ('2', '2021软件2班', '2');
INSERT INTO `t_class` VALUES ('3', '2021软件3班', '1');

在这里插入图片描述

(三)创建学生表

  • 执行SQL语句,创建学生表t_student
CREATE TABLE `t_student` (
  `s_id` int(11) NOT NULL AUTO_INCREMENT,
  `s_name` varchar(30) DEFAULT NULL,
  `s_gender` varchar(10) DEFAULT NULL,
  `s_age` int(11) DEFAULT NULL,
  `class_id` int(11) DEFAULT NULL,
  PRIMARY KEY (`s_id`)
) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8mb4;

  • 执行SQL语句,插入9条记录
INSERT INTO `t_student` VALUES ('1', '佟大为', '男', '20', '1');
INSERT INTO `t_student` VALUEs ('2', '李方玉', '女', '19', '1');
INSERT INTO `t_student` VALUES ('3', '郑大林', '男', '19', '2');
INSERT INTO `t_student` VALUES ('4', '温晓辉', '男', '18', '1');
INSERT INTO `t_student` VALUES ('5', '吴文静', '女', '19', '2');
INSERT INTO `t_student` VALUES ('6', '肖文艳', '女', '18', '3');
INSERT INTO `t_student` VALUES ('7', '杨文军', '男', '20', '3');
INSERT INTO `t_student` VALUES ('8', '唐雨涵', '女', '19', '2');
INSERT INTo `t_student` VALUES ('9', '金雨欣', '女', '20', '2');

在这里插入图片描述

三、创建与数据库表对应的实体类

(一)创建教师实体类

在这里插入图片描述

package net.huawei.mybatis.bean;

/**
 * 功能:教师实体类
 * 作者:华卫
 * 日期:2023年04月11日
 */
public class Teacher {
    private int id;
    private String name;

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    @Override
    public String toString() {
        return "Teacher{" +
                "id=" + id +
                ", name='" + name + '\'' +
                '}';
    }
}

(二)创建学生实体类

在这里插入图片描述

package net.huawei.mybatis.bean;

/**
 * 功能:学生实体类
 * 作者:华卫
 * 日期:2023年04月11日
 */
public class Student {
    private int id;
    private String name;
    private String gender;
    private int age;
    private Clazz clazz;

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getGender() {
        return gender;
    }

    public void setGender(String gender) {
        this.gender = gender;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    public Clazz getClazz() {
        return clazz;
    }

    public void setClazz(Clazz clazz) {
        this.clazz = clazz;
    }

    @Override
    public String toString() {
        return "Student{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", gender='" + gender + '\'' +
                ", age=" + age +
                ", clazz=" + clazz.getName() +
                '}';
    }
}

(三)创建班级实体类

在这里插入图片描述

package net.huawei.mybatis.bean;

import java.util.List;

/**
 * 功能:班级实体类
 * 作者:华卫
 * 日期:2023年04月11日
 */
public class Clazz {
    private int id;
    private String name;
    private Teacher teacher;
    private List<Student> students;

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Teacher getTeacher() {
        return teacher;
    }

    public void setTeacher(Teacher teacher) {
        this.teacher = teacher;
    }

    public List<Student> getStudents() {
        return students;
    }

    public void setStudents(List<Student> students) {
        this.students = students;
    }

    @Override
    public String toString() {
        return "Clazz{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", teacher=" + teacher.getName() +
                ", students=" + students +
                '}';
    }
}

四、创建班级映射器配置文件

在这里插入图片描述

<?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="net.huawei.mybatis.mapper.ClazzMapper">
    <!--按编号查询班级(带教师信息和学生信息),需要三表关联查询-->
    <select id="findById" parameterType="int" resultMap="clazzMap1">
        SELECT * FROM t_class
            INNER JOIN t_teacher ON t_class.teacher_id = t_teacher.t_id
	        INNER JOIN t_student ON t_class.c_id = t_student.class_id
	        WHERE c_id = #{id};
    </select>

    <!--定义班级结果映射-->
    <resultMap id="clazzMap1" type="Clazz">
        <result property="id" column="c_id"/>
        <result property="name" column="c_name"/>
        <!--一对一关联:一个班级配一个老师-->
        <association property="teacher" javaType="Teacher" column="teacher_id">
            <result property="id" column="t_id"/>
            <result property="name" column="t_name"/>
        </association>
        <!--一对多关联:一个班级有多个学生-->
        <collection property="students" ofType="Student">
            <result property="id" column="s_id"/>
            <result property="name" column="s_name"/>
            <result property="gender" column="s_gender"/>
            <result property="age" column="s_age"/>
            <association property="clazz" javaType="Clazz" column="class_id">
                <result property="name" column="c_name"/>
            </association>
        </collection>
    </resultMap>

    <!--##########################################################-->

    <!--查询全部班级(带教师信息,不带学生信息),利用嵌套查询实现一对一关联-->
    <select id="findAll" resultMap="clazzMap2">
        SELECT * FROM t_class;
    </select>
    
    <!--定义班级结果映射-->
    <resultMap id="clazzMap2" type="Clazz">
        <result property="id" column="c_id"/>
        <result property="name" column="c_name"/>
        <!--通过select属性定义子查询-->
        <association property="teacher" javaType="Teacher" column="teacher_id" select="getTeacher"/>
    </resultMap>
    
    <!--按编号查询教师-->
    <select id="getTeacher" resultType="Teacher">
        SELECT t_id id, t_name name FROM t_teacher WHERE t_id = #{id};
    </select>
</mapper>

五、修改mybatis配置文件

  • 在配置文件里配置班级、教师与学生实体类别名,以及班级映射器配置文件
    在这里插入图片描述

六、创建班级映射器接口

在这里插入图片描述

package net.huawei.mybatis.mapper;

import net.huawei.mybatis.bean.Clazz;

import java.util.List;

/**
 * 功能:班级映射器接口
 * 作者:华卫
 * 日期:2023年04月12日
 */
public interface ClazzMapper {
    Clazz findById(int id); // 按编号查询班级记录
    List<Clazz> findAll();   // 查询全部班级记录
}

七、创建班级映射器测试类

在这里插入图片描述

package net.huawei.mybatis.mapper;

import net.huawei.mybatis.bean.Clazz;
import net.huawei.mybatis.bean.Student;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;

import java.io.IOException;
import java.io.Reader;
import java.util.List;

/**
 * 功能:测试班级映射器
 * 作者:华卫
 * 日期:2023年04月12日
 */
public class TestClazzMapper {

    private SqlSession sqlSession; // SQL会话
    private ClazzMapper clazzMapper; // 班级映射器

    @Before
    public void init() {
        try {
            // 读取MyBatis配置文件
            Reader reader = Resources.getResourceAsReader("mybatis-config.xml");
            // 基于MyBatis配置文件构建SQL会话工厂
            SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(reader);
            // 利用SQL会话工厂获取SQL会话
            sqlSession = factory.openSession();
            // 利用SQL会话获取班级映射器对象
            clazzMapper = sqlSession.getMapper(ClazzMapper.class);
            // 提示用户SQL会话创建成功
            System.out.println("SQL会话创建成功~");
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    @Test // 按编号查询班级(带教师信息和学生信息)
    public void testFindById() {
        // 查询id为1的班级信息
        int id = 1;
        Clazz clazz = clazzMapper.findById(id);
        // 判断是否查询成功
        if (clazz != null) {
            // 打印班级信息
            System.out.println(clazz);
            // 打印班级学生信息
            System.out.println("班级编号为[" + id + "]的学生:");
            List<Student> students = clazz.getStudents();
            students.forEach(student -> System.out.println(student));

        } else {
            System.out.println("编号为[" + id + "]的班级不存在~");
        }
    }
    
    @Test // 查询全部班级信息
    public void testFindAll() {
        // 查询全部班级
        List<Clazz> clazzes = clazzMapper.findAll();
        // 输出全部班级
        clazzes.forEach(clazz -> System.out.println(clazz));
    }

    @After
    public void destroy() {
        // 关闭SQL会话
        sqlSession.close();
        // 提示用户SQL会话关闭
        System.out.println("SQL会话已经关闭~");
    }
}


(一)测试按编号查询班级方法

  • 运行测试方法testFindById(),查看结果
    在这里插入图片描述

(二)测试查询全部班级方法

  • 运行测试方法testFindAll(),查看结果
    在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/598567.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux系统搭建Java的运行环境

目录 JDKTomcatMySQL JDK 对于Linux安装JDK有很多方法~ 这里就掌握最简单的办法—基于yum来进行安装~ yum是“包管理器”&#xff0c;相当于应用商店~ 首先&#xff0c;先搜索一下&#xff0c;看看yum上关于jdk有没有&#xff0c;以及叫啥名字~ 通过 yum list命令&#xff0…

六一亲子嘉年华 | 来迅镭激光过一个五彩缤纷的儿童节!

童年是梦&#xff0c;如七彩的画卷&#xff1b; 童年是诗&#xff0c;如璀璨的星空&#xff1b; 童年是歌&#xff0c;如跳跃的音符&#xff01; 在“六一”儿童节到来之际 为给员工及子女创造一个难忘的亲子时光 迅镭激光开展了六一亲子嘉年华主题活动 让孩子们在迅镭大家庭的…

Minigpt4实战搭建

简介 Minigpt4虽然放出了网页版但是使用后发现网页体验的话&#xff0c;由于并发量比较大&#xff0c;很容易突然卡顿的现象&#xff0c;所以下面我主要讲解一下如何进行本地部署。 之前文章已经介绍过Minigpt4了这里就不重复赘述了&#xff0c;不了解的可以去看看https://bl…

使用python开发“魂斗罗”游戏

使用python开发“魂斗罗”游戏 开发完整的魂斗罗&#xff08;Contra&#xff09;游戏是一个庞大的任务&#xff0c;它涉及到图形渲染、物理碰撞、敌人AI、游戏关卡等多个方面。在这个简短的交互中&#xff0c;我将向你展示一个基本的魂斗罗风格的游戏框架&#xff0c;你可以在此…

结构化文档发布的故事和性能调优

前阵子一个TW朋友跟我抱怨他们的文档发布很慢。正常发布需要一个晚上才能完成发布。中间如果出点错&#xff0c;就得重新发布&#xff0c;那么中间是漫长的等待。 不像MS Word或者InDesign这样所见即所得的软件&#xff0c;结构化文档源文件是XML格式的&#xff0c;就像计算机…

C语言——数据在内存中的存储(下)

数据在内存中的存储&#xff08;下&#xff09; 1. 浮点数在内存中的存储 浮点数家族&#xff1a; float double long double 浮点数的表示范围&#xff1a; 这里要引用float.h头文件 【实例一】 //输出结果是什么&#xff1f; int main() {int n 9;float *pFloat (float…

【代码规范】Google开源项目风格指南

系列综述&#xff1a; &#x1f49e;目的&#xff1a;本系列是个人整理为了秋招面试的&#xff0c;整理期间苛求每个知识点&#xff0c;平衡理解简易度与深入程度。 &#x1f970;来源&#xff1a;材料主要源于Google开源项目风格指南进行的&#xff0c;每个知识点的修正和深入…

基于卡尔曼滤波实现线性目标跟踪

文章目录 前言卡尔曼滤波基本推导运算 实现目标检测卡尔曼预测器ID分配器&#xff08;跟踪器&#xff09; 完整代码代码总结 前言 一个需求&#xff0c;在一个稳定的场景当中&#xff0c;实现目标检测计数算法。 任务点&#xff1a; 实现目标检测完成对不同类别的物品进行计数…

Three.js--》实现3d字体模型展示

目录 项目搭建 初始化three.js基础代码 设置环境纹理 加载字体模型 今天简单实现一个three.js的小Demo&#xff0c;加强自己对three知识的掌握与学习&#xff0c;只有在项目中才能灵活将所学知识运用起来&#xff0c;话不多说直接开始。 项目搭建 本案例还是借助框架书写…

前后端交互模型http协议Ajax简介

0、前言&#xff1a;本文只是对“前后端交互模型&http协议&Ajax简介”当中的理论&#xff0c;作用&#xff0c;方法进行总结说明&#xff0c;用于回顾知识&#xff0c;做概括总结&#xff0c;没有具体实现代码。 1、前后端交互模型&#xff1a; 前端发送请求&#xff…

信号机制上(信号概念、发送、定时器、信号捕捉、SIGCHLD)

一、信号机制 概念&#xff1a;信号是在软件层次上对中断机制的一种模拟&#xff0c;是一种异步通信方式 所有信号的产生及处理全部都是由内核完成的 信号的产生&#xff1a; 1 按键产生 2 系统调用函数产生&#xff08;比如raise&#xff0c; kill&#xff09; 3 硬件异…

连接MQTT服务端

MQTT客户端之间要想实现通讯&#xff0c;必须要通过MQTT服务端。因此MQTT客户端无论是发布消息还是订阅消息&#xff0c;首先都要连接MQTT服务端。 MQTT客户端连接服务端一共有两步。 第一步&#xff08;CONNECT请求&#xff09; 首先MQTT客户端将会向服务端发送连接请求。该…

HBase 的关键流程解析

前言 本文隶属于专栏《大数据技术体系》&#xff0c;该专栏为笔者原创&#xff0c;引用请注明来源&#xff0c;不足和错误之处请在评论区帮忙指出&#xff0c;谢谢&#xff01; 本专栏目录结构和参考文献请见大数据技术体系 正文 HBase 客户端会将查询过的 HRegion 的位置信息…

【Python爬虫】采集电商商品评价信息

目录 一、数据采集逻辑二、数据Schema三、数据爬取1.导入库2.对爬虫程序进行伪装3.抓取商品评论信息4.防止反爬&#xff0c;每爬取一页数据后&#xff0c;设置程序休眠环节 四、数据存储1. 存储到csv 2.存储到数据库 一、数据采集逻辑 在进行数据采集之前&#xff0c;明确哪些…

Linux下C语言文件描述符操作(dup / dup2 / sendfile / splice / tee)

Linux的哲学是一切皆文件&#xff0c;而操作文件是通过文件描述符来进行。本文梳理一下dup / dup2 / sendfile / splice/ tee函数对文件描述符的操作。 目录 1.dup 2.dup2 3.sendfile 4.splice 5.tee 1.dup #include <unistd.h> int dup(int fd); 复制一个现有的…

Java基础(maven)——maven新建项目 常用IO工具 Durid数据库工具 案例

目录 引出用Maven建项目0.Maven配置方式1.io流的工具IOUtils/FileUtils1&#xff09;可以读文件、按照行读、读网页等&#xff1b;2&#xff09;配合hasmap进行简体繁体转换 2.durid数据库连接工具1&#xff09;创建连接&#xff0c;durid进行连接管理2&#xff09;查询的方式q…

chatgpt赋能python:Python中的转置函数-一种简单而高效的矩阵操作

Python中的转置函数 - 一种简单而高效的矩阵操作 作为一名10年的Python编程经验工程师&#xff0c;掌握利用Python进行矩阵操作是必不可少的。Python中提供了各种高效的矩阵操作功能&#xff0c;其中之一就是转置函数。 什么是转置&#xff1f; 在数学中&#xff0c;矩阵转置…

追寻幸福:探索幸福的关键特征和行为

目录 1. 积极的心态 2. 良好的人际关系 3. 自我接纳和自尊 4. 追求意义和目标 5. 健康的身心状态 6. 感知和实现个人价值 幸福是一个主观的感受&#xff0c;因此不同的人对于幸福的定义和追求方式可能会有所不同。然而&#xff0c;有一些共同的特点和行为模式&#xff0c…

【数据结构】难度上一个台阶的二叉树实现

【数据结构】难度上一个台阶的二叉树实现 一、什么是树和二叉树&#xff1f;二、目标三、实现3.1、初始化工作3.2、二叉树的前序遍历3.2.1、原理图解3.2.2、代码实现 3.3、二叉树的创建3.3.1、原理解析3.3.2、代码实现 3.4、二叉树的中序遍历3.5、二叉树的后序遍历3.6、二叉树的…

K8S系列文章之快速入门K8S

搭建K8S环境 前置 目前生产部署Kubernetes 集群主要有两种方式&#xff1a; kubeadm Kubeadm 是一个K8s 部署工具&#xff0c;提供kubeadm init 和kubeadm join&#xff0c;用于快速部署Kubernetes 集群。 官方地址&#xff1a;https://kubernetes.io/docs/reference/setu…