一个学生能够选多门课程,而一门课程能够由多个学生选择,这就是一个典型的多对多关联关系。所谓多对多关系,实际上是由两个互反的一对多关系组成。即多对多关系都会经过一个中间表来创建,例如选课表。学生对于选课表来讲是一对多,课程对于选课表来讲也是一对多。php
学生表咱们以前已经建立了t_student,这里就再也不从新建立了,下面建立一个课程表java
CREATE TABLE `t_course` ( `id` INT NOT NULL, `name` VARCHAR(20) NULL, PRIMARY KEY (`id`));
选课表:sql
CREATE TABLE `learnmybatis`.`t_student_course` ( `id` INT NOT NULL AUTO_INCREMENT, `sid` INT NULL, `cid` INT NULL, PRIMARY KEY (`id`));
初始化数据:数据库
INSERT INTO `learnmybatis`.`t_course` (`id`, `name`) VALUES ('1001', 'SpringMVC'); INSERT INTO `learnmybatis`.`t_course` (`id`, `name`) VALUES ('1002', 'mybatis'); INSERT INTO `learnmybatis`.`t_course` (`id`, `name`) VALUES ('1003', 'Spring'); INSERT INTO `learnmybatis`.`t_student_course` (`sid`, `cid`) VALUES ('1', '1001'); INSERT INTO `learnmybatis`.`t_student_course` (`sid`, `cid`) VALUES ('1', '1002'); INSERT INTO `learnmybatis`.`t_student_course` (`sid`, `cid`) VALUES ('1', '1003'); INSERT INTO `learnmybatis`.`t_student_course` (`sid`, `cid`) VALUES ('3', '1001'); INSERT INTO `learnmybatis`.`t_student_course` (`sid`, `cid`) VALUES ('3', '1002'); INSERT INTO `learnmybatis`.`t_student_course` (`sid`, `cid`) VALUES ('4', '1001');
建立Course类apache
package com.monkey1024.bean; import java.util.List; public class Course { private int id; private String name; private List<Student> students; //省略getter、setter和toString }
在以前的Student类中添加List属性表示课程:session
private List<Course> courses;
<?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="com.monkey1024.dao.CourseDao"> <resultMap id="courseMapper" type="Course"> <id property="id" column="cid"/> <result property="name" column="cname"/> <collection property="students" ofType="Student"> <id property="id" column="sid"/> <result property="name" column="sname"/> </collection> </resultMap> <select id="selectCourseStudent" resultMap="courseMapper"> SELECT c.id cid, c.name cname, s.id sid, s.name sname FROM t_course c, t_student s, t_student_course sc WHERE c.id = #{id} AND s.id = sc.sid AND c.id = sc.cid; </select> </mapper>
上面sql语句是三张表的关联查询,在collection中表示查询出的学生数据,这里其实能够看作是一对多的查询,由于咱们指定了课程编号。mybatis
package com.monkey1024.dao; import com.monkey1024.bean.Course; public interface CourseDao { Course selectCourseStudent(int id); }
package com.monkey1024.test; import com.monkey1024.bean.Course; import com.monkey1024.bean.Employee; import com.monkey1024.dao.CourseDao; import com.monkey1024.dao.EmployeeDao; import com.monkey1024.util.MyBatisUtil; import org.apache.ibatis.session.SqlSession; import org.junit.After; import org.junit.Before; import org.junit.Test; import java.util.List; public class CourseTest01 { private SqlSession sqlSession; private CourseDao courseDao; /** * 测试时先执行该方法建立EmployeeDao对象 */ @Before public void initStudentDao(){ sqlSession = MyBatisUtil.getSqlSession(); //经过该方法能够获取CourseDao的对象 courseDao = sqlSession.getMapper(CourseDao.class); } /** * 执行完成后须要关闭sqlSession */ @After public void closeSession() { if (sqlSession != null) { sqlSession.close(); } } @Test public void selectCourseStudent(){ Course course = courseDao.selectCourseStudent(1001); System.out.println(course); } }
执行结束后能够看到将课程和选择该课程的全部学生所有查询出来了。app