Mybatis多对多查询案例!

在MyBatis中执行多对多查询需要使用两个主要表和一个连接表(通常称为关联表)来演示。在这个示例中,我们将使用一个示例数据库模型,其中有三个表:`students`、`courses` 和 `student_courses`,它们之间建立了多对多关系。`students` 表存储学生信息,`courses` 表存储课程信息,`student_courses` 表用于将学生与他们所选的课程关联起来。

以下是如何在MyBatis中执行多对多查询的步骤:

  1. 创建数据库表和数据。首先,确保你已经创建了适当的数据库表并插入了示例数据。以下是表的基本结构:
  • `students` 表包含 `student_id` 和 `student_name` 列。

  • `courses` 表包含 `course_id` 和 `course_name` 列。

  • `student_courses` 表用于将学生与课程关联,包含 `student_id` 和 `course_id` 列。

  1. 创建 MyBatis 映射文件。你需要创建一个MyBatis映射文件来定义SQL查询。以下是一个示例映射文件的结构:

```xml

XML 复制代码
<mapper namespace="com.example.StudentCourseMapper">
    <select id="getStudentCourses" parameterType="int" resultMap="studentCourseResult">
        SELECT s.student_id, s.student_name, c.course_id, c.course_name
        FROM students s
        JOIN student_courses sc ON s.student_id = sc.student_id
        JOIN courses c ON sc.course_id = c.course_id
        WHERE s.student_id = #{studentId}
    </select>
    
    <resultMap id="studentCourseResult" type="com.example.StudentCourse">
        <result property="studentId" column="student_id"/>
        <result property="studentName" column="student_name"/>
        <result property="courseId" column="course_id"/>
        <result property="courseName" column="course_name"/>
    </resultMap>
</mapper>

```

  1. 创建Java模型类。创建一个Java模型类来表示多对多关系的结果。例如,可以创建一个名为 `StudentCourse` 的类:

```java

java 复制代码
public class StudentCourse {
    private int studentId;
    private String studentName;
    private int courseId;
    private String courseName;

    // 省略 getter 和 setter 方法
}

```

  1. 创建Mapper接口。创建一个Mapper接口,定义用于执行多对多查询的方法:

```java

java 复制代码
public interface StudentCourseMapper {
    List<StudentCourse> getStudentCourses(int studentId);
}

```

  1. 配置MyBatis。在MyBatis的配置文件中配置数据源和映射文件。

  2. 执行多对多查询。在应用程序中调用 `getStudentCourses` 方法,将学生的 `studentId` 作为参数传递:

```java

java 复制代码
SqlSessionFactory sqlSessionFactory = MyBatisConfig.getSqlSessionFactory();
try (SqlSession session = sqlSessionFactory.openSession()) {
    StudentCourseMapper mapper = session.getMapper(StudentCourseMapper.class);
    List<StudentCourse> studentCourses = mapper.getStudentCourses(1); // 传入学生的ID
    for (StudentCourse sc : studentCourses) {
        System.out.println("Student: " + sc.getStudentName() + ", Course: " + sc.getCourseName());
    }
}

```

这将执行查询,返回与给定学生相关的课程列表。

以上示例演示了如何在MyBatis中执行多对多查询。你可以根据自己的数据模型和需求进行相应的调整。

相关推荐
GBASE15 小时前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
xiezhr1 天前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
吃糖的小孩2 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
笃行3503 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3503 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3503 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库
SelectDB4 天前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台
大数据·数据库·aigc
这个DBA有点耶4 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构
掉头发的王富贵4 天前
【StarRocks】极限十分钟入门StarRocks
数据库·sql·mysql