Mybatis 级联查询 (一对多 )
后台系统中 涉及到添加试卷 问题 答案的一个模块的。我需要通过试卷 查询出所有的试题,以及试题的答案。这个主要要使用到Mybatis的级联查询。
通过试卷 查询出与该试卷相关的试题(一对多),查询出试题的答案及分数(一对多)。
SelfTestTitle 实体类,SelfTestQuestion实体类,SelfTestAnswer实体类。
package org.system.entity.self;
import java.util.List;
import org.core.entity.BaseEntity;
public class SelfTestTitle extends BaseEntity {
private Integer id;
private String name;
private String desc;
private String picUrl;
private List<SelfTestQuestion> questionList;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getDesc() {
return desc;
}
public void setDesc(String desc) {
this.desc = desc;
}
public String getPicUrl() {
return picUrl;
}
public void setPicUrl(String picUrl) {
this.picUrl = picUrl;
}
public List<SelfTestQuestion> getQuestionList() {
return questionList;
}
public void setQuestionList(List<SelfTestQuestion> questionList) {
this.questionList = questionList;
}
@Override
public Integer getPage() {
return super.getPage();
}
@Override
public Integer getRows() {
return super.getRows();
}
}
package org.system.entity.self; import java.util.List; import javax.validation.constraints.NotNull; import org.core.entity.BaseEntity;
import org.hibernate.validator.constraints.NotBlank;
import org.utils.spring.Groups; public class SelfTestQuestion extends BaseEntity {
private Integer id; @NotNull(message = "{selfTestTitle.id.notnull.valid}", groups = { Groups.Insert.class })
private Integer titleId; @NotBlank(message = "{question.notblank.valid}", groups = { Groups.Insert.class })
private String question; @NotNull(message = "{viewOrder.notnull.valid}", groups = { Groups.Insert.class })
private Integer viewOrder; private List<SelfTestAnswer> answersList; public Integer getId() {
return id;
} public void setId(Integer id) {
this.id = id;
} public Integer getTitleId() {
return titleId;
} public void setTitleId(Integer titleId) {
this.titleId = titleId;
} public String getQuestion() {
return question;
} public void setQuestion(String question) {
this.question = question;
} public Integer getViewOrder() {
return viewOrder;
} public void setViewOrder(Integer viewOrder) {
this.viewOrder = viewOrder;
} public List<SelfTestAnswer> getAnswersList() {
return answersList;
} public void setAnswersList(List<SelfTestAnswer> answersList) {
this.answersList = answersList;
} @Override
public Integer getPage() {
return super.getPage();
} @Override
public Integer getRows() {
return super.getRows();
}
}
package org.system.entity.self;
import org.core.entity.BaseEntity;
public class SelfTestAnswer extends BaseEntity {
private Integer id;
private Integer questionId;
private String answer;
private Integer score;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public Integer getQuestionId() {
return questionId;
}
public void setQuestionId(Integer questionId) {
this.questionId = questionId;
}
public String getAnswer() {
return answer;
}
public void setAnswer(String answer) {
this.answer = answer;
}
public Integer getScore() {
return score;
}
public void setScore(Integer score) {
this.score = score;
}
@Override
public Integer getPage() {
return super.getPage();
}
@Override
public Integer getRows() {
return super.getRows();
}
}
<!-- 查询试卷详情 -->
<select id="queryOne" parameterType="org.system.entity.self.SelfTestTitle" resultMap="getSelfTestQuestionMap">
select id, name, `desc` de, pic_url picUrl
from self_test_title
where id = #{id}
</select>
<!-- 定义结果集 试卷下的问题 -->
<resultMap type="map" id="getSelfTestQuestionMap">
<result property="id" column="id" />
<collection property="questionList" column="id" javaType="list" select="getSelfTestQuestions"/>
</resultMap> <!-- 查询问题 -->
<select id="getSelfTestQuestions" parameterType="org.system.entity.self.SelfTestTitle" resultMap="getSelfTestAnswersMap">
select id, title_id titleId, question, view_order viewOrder
from self_test_question
where title_id = #{id}
</select> <!-- 定义结果集 问题下的答案 -->
<resultMap type="map" id="getSelfTestAnswersMap">
<result property="id" column="id"/>
<collection property="answersList" column="id" javaType="list" select="getSelfTestAnswers"></collection>
</resultMap>
<!-- 查询问题 -->
<select id="getSelfTestAnswers" parameterType="org.system.entity.self.SelfTestAnswer" resultType="map">
select id ,question_id questionId,answer ,score from self_test_answer where question_id =#{id}
</select>
property:属性名称
column:外键列
javaType:类型(可以是自己的实体类)
select:关联的查询语句
collection:一对多的标签
property:属性名称
column:外键列
查询出来的结果

现在主要是要让他显示出来了!
Mybatis 级联查询 (一对多 )的更多相关文章
- mybatis ---- 级联查询 一对多 (集合映射)
关联有嵌套查询和嵌套结果两种方式,本文是按照嵌套结果这种方式来说明的 上一章介绍了多对一的关系,用到了<association></association>,这是一个复杂类型的 ...
- Mybatis 之级联查询 一对多配置
Mybatis级联 查询相对于hibenate是有点麻烦,但是相应好处也是有的,Mybatis轻量.根据自己要的字段配置方便 一对多配置用 <collection property=&quo ...
- mybatis级联查询,多对一查询问题
在使用Mybatis进行多表级联查询时遇到了一个问题:查询结果只有一项,但正确结果是两项.经测试,SQL语句本身没有问题. 在SQL映射文件(XML)中: <!-- 级联查询数据 --> ...
- mybatis级联查询
1.定义四个实体.User Role Privilege Resource,他们之间的对于关系为 2.需求:我通过用户名username查找出该用户对应的角色以及角色对应的权限和资源 3 ...
- Mybatis 级联查询时只查出了一条数据
造成这个问题的原因是: 主表和明细表的id字段名相同造成的. 问题的关键在于resultMap中如果不定义类似主键之类的能够区分每一条结果集的字段的话,会引起后面一条数据覆盖前面一条数据的现象.
- Mybatis中使用级联查询,一对多的查询
一.需求描述 自己在开发一个小程序的过程中,需要做的一个查询是稍微比较复杂的查询,根据用户信息去查询用户所对应的宠物信息. 一个用户可能对应多个宠物,所以在用户和宠物信息的对应关系就是一对多的关系. ...
- Mybatis 一对一、一对多、多对多关联之级联添加
示例项目:MIPO_CRM 一.一对一关联 示例:订单与销售机会 描述:在业务员与客户的联系人的联系记录中可以生成一条销售机会,而此条销售机会可生成一条订单,两者呈一对一关联. 1.表设计 oppor ...
- MyBatis关联查询,一对多关联查询
实体关系图,一个国家对应多个城市 一对多关联查询可用三种方式实现: 单步查询,利用collection标签为级联属性赋值: 分步查询: 利用association标签进行分步查询: 利用collect ...
- mybatis实战教程二:多对一关联查询(一对多)
多对一关联查询 一.数据库关系.article表和user表示多对一的关系 CREATE TABLE `article` ( `id` ) NOT NULL AUTO_INCREMENT, `user ...
随机推荐
- Unity中HDR外发光的使用
1.使用标准材质,设置好Emission外发光 2.Camera下打开HDR,加上Bloom特效 最终效果 如果只勾选HDR,只会有高光感,不会有外发光 注意,正向光照下打开HDR不可用抗锯齿,否则切 ...
- Discuz! 6.x/7.x 全局变量防御绕过导致命令执行
https://www.secpulse.com/archives/2338.html 模拟register_globals功能的代码,在GPC为off时会调用addslashes()函数处理变量值, ...
- InheritableThreadLocal原理
转载:https://github.com/pzxwhc/MineKnowContainer/issues/20 介绍 InheritableThreadLocal 之前,假设对 ThreadLoca ...
- hibernate的dao中参数的传递取值
hibernate的dao中参数的传递取值 private Query setParameter(Query query, Map<String, Object> map) { if (m ...
- exp函数
第一种是tensor用exp函数 th> a [torch.DoubleTensor of size 1x3] [.0002s] th> a:exp() 2.7183 2.7183 1.0 ...
- reactjs入门到实战(一)---- hello world例子
React 起源于 Facebook 的内部项目,因为该公司对市场上所有 JavaScript MVC 框架,都不满意,就决定自己写一套,用来架设 Instagram 的网站.做出来以后,发现这套东西 ...
- 如何快速清除.svn文件
Windows Registry Editor Version 5.00[HKEY_LOCAL_MACHINE\SOFTWARE\Classes\Folder\shell\清除SVN信息] @=&qu ...
- 优化Linux生产服务器的经验之谈
[51CTO独家特稿]如何优化自己的Linux生产服务器?本文结合实际的工作经验,总结了优化Linux生产服务器的九大要点.如果有些方法您尚未采用,不妨一试. 一.时间同步 生产环境下的服务器对时间的 ...
- HDU 5059 Harry And Biological Teacher
链接:http://acm.hdu.edu.cn/showproblem.php?pid=5069 题意:给出n个串,m个询问,每个询问(u,v),求u的一个最长后缀是v的前缀. 思路:离线.将关于u ...
- 从Unity学UE(一)之蓝图类的使用----制作一个可控灯光
转自:http://blog.csdn.net/u011707076/article/details/44171829 首先申明,本文章内容适合有Unity引擎基础的童鞋享用,如果不了解Unity引擎 ...