MyBatis对象关联关系----多对多的保存与查询
模拟情景:
对象:学生,课程
关系:一个学生可选多个课程,一门课程可被多个学生选择
一、保存
1.创建数据库表,student,course,student_course,其中student_course用来关联学生表与课程表注意在设计表的字段时,字段名不要相同,尤其是主键的字段名不要相同,不然在查询的时候使用collection集合只出现一条结果。student_course表中的s_id,c_id作为外键关联到student,course表的主键
DROP TABLE IF EXISTS `course`;
CREATE TABLE `course` (
`cid` int(8) NOT NULL AUTO_INCREMENT,
`cnumber` varchar(20) COLLATE utf8_bin DEFAULT NULL,
`cname` varchar(20) COLLATE utf8_bin DEFAULT NULL,
PRIMARY KEY (`cid`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8 COLLATE=utf8_bin; DROP TABLE IF EXISTS `student`;
CREATE TABLE `student` (
`sid` int(8) NOT NULL AUTO_INCREMENT,
`name` varchar(20) COLLATE utf8_bin DEFAULT NULL,
PRIMARY KEY (`sid`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8 COLLATE=utf8_bin; DROP TABLE IF EXISTS `student_course`;
CREATE TABLE `student_course` (
`sc_id` int(8) NOT NULL AUTO_INCREMENT,
`s_id` int(8) NOT NULL,
`c_id` int(8) NOT NULL,
PRIMARY KEY (`sc_id`),
KEY `10001` (`s_id`),
KEY `10002` (`c_id`),
CONSTRAINT `10002` FOREIGN KEY (`c_id`) REFERENCES `course` (`cid`) ON DELETE CASCADE ON UPDATE CASCADE,
CONSTRAINT `10001` FOREIGN KEY (`s_id`) REFERENCES `student` (`sid`) ON DELETE CASCADE ON UPDATE CASCADE
) ENGINE=InnoDB AUTO_INCREMENT=15 DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
2.创建实体对象
public class Student {
private int id;
private String name;
private List<Course> course ;//所选课程
//...省略get、set方法
}
public class Course {
private int cid;
private String cnumber;
private String cname;
private List<Student> student ;//选择该课程的学生
//...省略get、set方法
}
3.编写接口方法
public interface IStudentDao {
public Student getById(int id);
public void saveSelectCourse(@Param("student") Student s,@Param("course") Course c);
public Student getStudentCourse(int id);
}
4.编写sql映射文件student.xml
<mapper namespace="com.mybaits.dao.IStudentDao">
<select id="getById" parameterType="int" resultType="Student">
select * from student where id=#{id}
</select>
<insert id="saveSelectCourse" >
insert into student_course(sid,cid) values(#{student.id} ,#{course.id})
</insert> </mapper>
5.在主配置文件中添加mapper,编写测试类
public class StudentTest {
private SqlSessionTemplate sqlSessionTemplate;
@Before
public void init(){
ApplicationContext ctx=new ClassPathXmlApplicationContext("spring.xml");
sqlSessionTemplate=(SqlSessionTemplate) ctx.getBean("sqlSessionTemplate");
}
@Test
public void test(){
IStudentDao student=sqlSessionTemplate.getMapper(IStudentDao.class);
Student s=student.getById(1);
ICourseDao course=sqlSessionTemplate.getMapper(ICourseDao.class);
Course c=course.getById(1);
student.saveSelectCourse(s, c);
System.out.println("save succeed!");
}
}
。。。。。。。。。。。。。运行结束。。。。。。。。。。。
二、查询
1.根据学生id查询学生信息,以及其选课信息,(通过id查询课程信息以及选择该课程的学生信息,两者的方法基本相同)接口方法已在上文保存中给出public Student getStudentCourse(int id);
2.sql映射文件语句
<resultMap type="com.mybaits.bean.Course" id="courseResult">
<id property="cid" column="cid"/>
<result property="cnumber" column="cnumber"/>
<result property="cname" column="cname"/>
</resultMap>
<resultMap type="com.mybaits.bean.Student" id="studentResult" >
<id property="id" column="sid"/>
<result property="name" column="name"/>
//使用collection元素来映射course集合,在collection中再嵌套resultMap,将集合中的元素映射成course对象
<collection property="course" ofType="com.mybaits.bean.Course" resultMap="courseResult">
</collection>
</resultMap>
<select id="getStudentCourse" parameterType="int" resultMap="studentResult">
select s.*,c.* from student s left join student_course sc on s.sid=sc.s_id left join course c on c.cid=sc.c_id where s.sid=#{id}
</select>
3.编写测试类
@Test
public void test2(){
IStudentDao student=sqlSessionTemplate.getMapper(IStudentDao.class);
Student s=student.getStudentCourse(1);
System.out.println("学生姓名:"+s.getName()+"\n选择课程:");
for(Course c:s.getCourse()){
System.out.println("课程编号:"+c.getCnumber()+"\t课程名称:"+c.getCname());
} }
运行结果:
学生姓名:mike
选择课程:
课程编号:s001 课程名称:JAVA
课程编号:s002 课程名称:C Language
MyBatis对象关联关系----多对多的保存与查询的更多相关文章
- MyBatis对象关联关系---- association与collection
Mybatis处理“一对多”的关系时,需要用到associasion元素.处理”多对一“用collection元素来实现(这两个元素在之前mapper文件中提到过). 本例子中,假设一名User可以有 ...
- MyBatis加强(1)~myBatis对象关系映射(多对一关系、一对多关系)、延迟/懒加载
一.myBatis对象关系映射(多对一关系.一对多关系) 1.多对一关系: ---例子:多个员工同属于一个部门. (1)myBatis发送 额外SQL: ■ 案例:员工表通过 dept_id 关联 部 ...
- mybatis 一对多的注入 指的是连表查询时候 将不同的查询结果以列表存储对象形式 注入进去 多对一指的是 查询多条结果但都是一样的 只需注入一条
mybatis 一对多的注入 指的是连表查询时候 将不同的查询结果以列表存储对象形式 注入进去 多对一指的是 查询多条结果但都是一样的 只需注入一条
- mybatis之关联关系
前言:在我们之前的hibernate中我们是学过了关联关系的,所以我们在本章给讲一讲mybatis的关联关系. mybatis的关联关系一对多的测试1.通过逆向工程生成Hbook,HbookCateg ...
- mybatis一对一关联关系映射
mybatis一对一关联关系映射 在关联关系中,有一对一,一对多,多对多三种关联关系. 一对一关系:在操作上,任意一方引入对方的主键作为外键. 一对多关系:在"多"的一方添加&qu ...
- Django QuerySet 方法梳理 。model外键 多对多的保存
引用:https://feifeiyum.github.io/2017/03/28/python-django-queryset/ 说明 Models 层是 Django 框架中最强大的部分之一, 大 ...
- Django框架(十)—— 多表操作:一对一、一对多、多对多的增删改,基于对象/双下划线的跨表查询、聚合查询、分组查询、F查询与Q查询
目录 多表操作:增删改,基于对象/双下划线的跨表查询.聚合查询.分组查询.F查询与Q查询 一.创建多表模型 二.一对多增删改表记录 1.一对多添加记录 2.一对多删除记录 3.一对多修改记录 三.一对 ...
- C#开发中使用配置文件对象简化配置的本地保存
C#开发中使用配置文件对象简化配置的本地保存 0x00 起因 程序的核心是数据和逻辑,开发过程中免不了要对操作的数据进行设置,而有些数据在程序执行过程中被用户或程序做出的修改是应该保存下来的,这样程序 ...
- 关系/对象映射 多对多关系(@ManyToMany 注释)【重新认识】
old: @ManyToMany 注释:表示此类是多对多关系的一边, mappedBy 属性定义了此类为双向关系的维护端, 注意:mappedBy 属性的值为此关系的另一端的属性名. 例如,在Stud ...
随机推荐
- Bug是一种财富-------研发同学的错题集、测试同学的遗漏用例集
此文已由作者王晓明授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 各位看官,可能看到标题的你一定认为这是一篇涉嫌"炒作"的文章,亦或是为了吸引眼球而起的标 ...
- 如何从“点子”落地到“执行”?—完整解析1个手游传播类mini项目的进化
本文来自网易云社区 作者:林玮园 从点子到落地,是不确定到确定的过程,是从模糊概念到具体现实的实现过程.无论什么点子,在落地变现的过程中都会有很多疑问产生. 首先,不确定点子本身是否成立.点子的背后是 ...
- 【个人笔记】关于C++小数的处理
无论是C-Style还是C++-Style的输出,小数都会四舍五入.如果想要截断两种比较好的方法.第一种:利用sscanf输出成字符串,再人为地putchar().第二种:已知钦定保留6位小数,那么可 ...
- 7.0 启动app权限弹窗问题
这里提供两种解决方案! 1.安卓6.0+是可以直接利用uiautomator定位元素点击!这个不细说,定位方式很多种...这个等待时间大家自己定大概两到三秒即可! #安卓6.0+点击方式driver. ...
- TTY锁屏与解锁
今天在tmux中使用vim时,不小心按了CTRL+S,结果整个vim不能使用了,在网上查到这里会有锁屏的问题,具体如下: 在tmux中,按CTRL+S,锁屏,按CTRL+Q,解锁.与系统的锁屏和解锁是 ...
- 问题 D: 约数的个数
问题 D: 约数的个数 时间限制: 1 Sec 内存限制: 32 MB提交: 272 解决: 90[提交][状态][讨论版][命题人:外部导入] 题目描述 输入n个整数,依次输出每个数的约数的个数 ...
- day-13 python库实现简单非线性回归应用
一.概率 在引入问题前,我们先复习下数学里面关于概率的基本概念 概率:对一件事发生的可能性衡量 范围:0<=P<=1 计算方法:根据个人置信区间:根据历史数据:根据模拟数据. 条件概率:B ...
- [译]如何比较同一分支上的不同commit的代码区别?
原文来源:https://stackoverflow.com/questions/3338126/how-do-i-diff-the-same-file-between-two-different-c ...
- 前台如何处理后台返回的json数据
后台返回的json数据格式: { "state": true, "data": { "id": 0, "name": & ...
- 《Hadoop基础教程》之初识Hadoop(转载)
转载自博主:上善若水任方圆http://blessht.iteye.com/blog/2095675 Hadoop一直是我想学习的技术,正巧最近项目组要做电子商城,我就开始研究Hadoop,虽然最后鉴 ...