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

相关推荐
m0_734949799 分钟前
MySQL如何配置定时清理过期备份文件_find命令与保留周期策略
jvm·数据库·python
m0_5145205740 分钟前
MySQL索引优化后性能没提升_通过EXPLAIN查看索引命中率
jvm·数据库·python
NaMM CHIN1 小时前
sql实战解析-sum()over(partition by xx order by xx)
数据库·sql
2601_949817721 小时前
Spring Boot3.3.X整合Mybatis-Plus
spring boot·后端·mybatis
不瘦80斤不改名1 小时前
深入浅出 MySQL(一):一文理清 SQL 核心规范与五大分类
数据库·sql·mysql
woniu_buhui_fei1 小时前
MySQL知识整理二
数据库·mysql
Polar__Star2 小时前
如何在 AWS Lambda 中正确使用临时凭证生成 S3 预签名 URL
jvm·数据库·python
Lucifer三思而后行2 小时前
zCloud 中 Oracle 实例状态未知问题记录
数据库·oracle
island13142 小时前
最详细VMware Workstation 17 上安装 Ubuntu 系统
linux·数据库·ubuntu
卢傢蕊2 小时前
MongoDB
数据库·mongodb