后台系统中 涉及到添加试卷 问题 答案的一个模块的。我需要通过试卷 查询出所有的试题,以及试题的答案。这个主要要使用到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 级联查询 (一对多 )的更多相关文章

  1. mybatis ---- 级联查询 一对多 (集合映射)

    关联有嵌套查询和嵌套结果两种方式,本文是按照嵌套结果这种方式来说明的 上一章介绍了多对一的关系,用到了<association></association>,这是一个复杂类型的 ...

  2. Mybatis 之级联查询 一对多配置

    Mybatis级联 查询相对于hibenate是有点麻烦,但是相应好处也是有的,Mybatis轻量.根据自己要的字段配置方便 一对多配置用   <collection property=&quo ...

  3. mybatis级联查询,多对一查询问题

    在使用Mybatis进行多表级联查询时遇到了一个问题:查询结果只有一项,但正确结果是两项.经测试,SQL语句本身没有问题. 在SQL映射文件(XML)中: <!-- 级联查询数据 --> ...

  4. mybatis级联查询

    1.定义四个实体.User   Role    Privilege   Resource,他们之间的对于关系为 2.需求:我通过用户名username查找出该用户对应的角色以及角色对应的权限和资源 3 ...

  5. Mybatis 级联查询时只查出了一条数据

    造成这个问题的原因是: 主表和明细表的id字段名相同造成的. 问题的关键在于resultMap中如果不定义类似主键之类的能够区分每一条结果集的字段的话,会引起后面一条数据覆盖前面一条数据的现象.

  6. Mybatis中使用级联查询,一对多的查询

    一.需求描述 自己在开发一个小程序的过程中,需要做的一个查询是稍微比较复杂的查询,根据用户信息去查询用户所对应的宠物信息. 一个用户可能对应多个宠物,所以在用户和宠物信息的对应关系就是一对多的关系. ...

  7. Mybatis 一对一、一对多、多对多关联之级联添加

    示例项目:MIPO_CRM 一.一对一关联 示例:订单与销售机会 描述:在业务员与客户的联系人的联系记录中可以生成一条销售机会,而此条销售机会可生成一条订单,两者呈一对一关联. 1.表设计 oppor ...

  8. MyBatis关联查询,一对多关联查询

    实体关系图,一个国家对应多个城市 一对多关联查询可用三种方式实现: 单步查询,利用collection标签为级联属性赋值: 分步查询: 利用association标签进行分步查询: 利用collect ...

  9. mybatis实战教程二:多对一关联查询(一对多)

    多对一关联查询 一.数据库关系.article表和user表示多对一的关系 CREATE TABLE `article` ( `id` ) NOT NULL AUTO_INCREMENT, `user ...

随机推荐

  1. 第十二届浙江省大学生程序设计大赛-May Day Holiday 分类: 比赛 2015-06-26 14:33 10人阅读 评论(0) 收藏

    May Day Holiday Time Limit: 2 Seconds Memory Limit: 65536 KB As a university advocating self-learnin ...

  2. Uva 10118 免费糖果

    题目链接:https://uva.onlinejudge.org/external/101/10118.pdf 参考:http://www.cnblogs.com/kedebug/archive/20 ...

  3. pandas安装过程中提示unable to find vcvarsall.bat的解决方法

    转载自:http://blog.csdn.net/qq_21144699/article/details/46849561 为这位老兄点赞 原帖参考:http://stackoverflow.com/ ...

  4. 基于@AspectJ和schema的aop(三)---切点函数详解

    切点函数是AspectJ表达式语言的核心, 也是使用@AspectJ进行切面定义的难点.本小节我们通过具体的实例对切点函数进行深入学习. 1.@annotation() @annotation()表示 ...

  5. Intel Code Challenge Final Round (Div. 1 + Div. 2, Combined) B

    Description You are given a table consisting of n rows and m columns. Numbers in each row form a per ...

  6. grails的layouts模板页面使用

    使用方式1: layouts文件夹下新建文件,名称和Controller名称相同,例如UserController,layouts下面创建user.gsp,此时,user站点下所有的页面都将套用 us ...

  7. 解决discuz论坛搬家:“Table ‘common_syscache’ is read only”问题

    解决discuz论坛搬家:“Table ‘common_syscache’ is re http://www.zixuephp.com/wzht/discuz/20141203_11562.html ...

  8. 看懂UML类图和时序图

    看懂UML类图和时序图 这里不会将UML的各种元素都提到,我只想讲讲类图中各个类之间的关系: 能看懂类图中各个类之间的线条.箭头代表什么意思后,也就足够应对 日常的工作和交流: 同时,我们应该能将类图 ...

  9. JavaScript运算符

    JavaScript运算符 1.算数运算符 设定a = 5. 运算符 描述 例子 结果 + 加 b=a+2 b=7 - 减 b=a-2 b=3 * 乘 b=a*2 b=10 / 除 b=a/2 b=2 ...

  10. SQLServer: 解决“错误15023:当前数据库中已存在用户或角色

    解决SQL Server 2008 错误15023:当前数据库中已存在用户或角色,SQLServer2008,错误15023, 在使用SQL Server 2008时,我们经常会遇到一个情况:需要把一 ...