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

相关推荐
Dubhehug12 分钟前
4.B树和B+树的区别?为什么MySQL选择B+树作为索引?
数据库·b树·mysql·面试·b+树
linux修理工44 分钟前
n1 armbian 安装桌面环境并启用xrdp远程登录
linux·服务器·数据库
开开心心就好2 小时前
高效报价软件,简化商铺定价流程
服务器·数据库·安全·面试·职场和发展·电脑·symfony
钢铁男儿3 小时前
PyQt5高级界而控件(容器:装载更多的控件QDockWidget)
数据库·python·qt
阿蒙Amon6 小时前
C# Linq to SQL:数据库编程的解决方案
数据库·c#·linq
互联网搬砖老肖10 小时前
运维打铁: MongoDB 数据库集群搭建与管理
运维·数据库·mongodb
netyeaxi11 小时前
Java:使用spring-boot + mybatis如何打印SQL日志?
java·spring·mybatis
典学长编程11 小时前
数据库Oracle从入门到精通!第四天(并发、锁、视图)
数据库·oracle
小七mod11 小时前
【MyBatis】MyBatis与Spring和Spring Boot整合原理
spring boot·spring·mybatis
积跬步,慕至千里11 小时前
clickhouse数据库表和doris数据库表迁移starrocks数据库时建表注意事项总结
数据库·clickhouse