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中执行多对多查询。你可以根据自己的数据模型和需求进行相应的调整。

相关推荐
Jay_Franklin4 分钟前
Python中使用sqlite3模块和panel完成SQLite数据库中PDF的写入和读取
数据库·笔记·python·pycharm·sqlite·pdf·py
小锅巴1231 小时前
百度测开面经(分类版)
数据库·分类·数据挖掘
芒果要切1 小时前
Redis 使用场景
数据库·redis·缓存
全栈工程师修炼指南1 小时前
DBA | Oracle RMAN 实战:物理备份与数据恢复全解析
数据库·oracle·dba
现在,此刻1 小时前
clickhouse和pgSql跨库查询方案对比
数据库·sql·clickhouse·性能优化
while(1){yan}2 小时前
数据库的基本操作
数据库·oracle
翻斗花园牛图图-2 小时前
MySQL——库的操作
数据库·mysql
大猫会长2 小时前
supabase备份数据库中某个schema的方法
数据库·oracle
-指短琴长-2 小时前
MySQL快速入门——内置函数
android·数据库·mysql
小码过河.4 小时前
告别 mysqldump 痛点!用 mydumper 实现 MySQL 高效备份与恢复
数据库·mysql