MongoDB实现问卷考试设计功能


本文整理自网络,侵删。

MongoDB的特点

MongoDB是一个面向文档存储的数据库。在MongoDB中,一条记录叫做document(文档),由类似于JSON结构的键值对组成。 

由于类似于MongoDB直接存储JSON的特性,MongoDB天生适合作为存储结构复杂的数据结构的介质。类似于问卷调查和考试这种需求,用mysql这种关系型数据库实现起来太过复杂,效率低下;而如果使用MongoDB来实现的话,则会发现异常清晰简单。

需求分析

在一张试卷中,会有很多个问题,问题的类型大体上可以分为单选题、多选题、判断题、简答题等。每一个问题又会有很多个选项,选项可以是文字描述也可以是图片又或者图文结合。

那么一张试卷的JSON格式应该大体上长成这样:

当然这只是最简单的数据结构,要完成一张试卷,还需要加入更多的属性。

结构设计

我们采用自底向上的结构设计方式,先对每个选项的数据结构进行设计。

选项设计

public class Option {
 /**
  * 选项类型
  */
 private Integer oType = 1;

 /**
  * 选项内容
  */
 private String text;
 
 /**
  * 选项图片
  */
 private String img;

 /**
  * 是否正确答案
  */
 private Boolean right;

 /**
  * 用户是否选择
  */
 private Boolean selected;
 ...

选项类型 oType 用来标志选项是普通文本还是图片或者图文; right 用来标志这个选项是否是正确答案,用于自动判卷; selected 用来标志用户有没有选择这个答案。

问题设计

 

public class Question extends MongoBean {
 /**
  * 数据的id
  */
 private String dataId;
 /**
  * 题目类型,1判断题;2单选题;3多选题
  */
 private Integer qType;
 /**
  * 题目标题
  */
 private String title;
 /**
  * 题目选项
  */
 private List<Option> options;
 /**
  * 数据类型
  * @see rmjk.enums.BizTypeEnum
  */
 private Integer dataType;
 /**
  * 数据标题
  */
 private String dataTitle;
 /**
  * 解析
  */
 private String analysis;
 /**
  * 这题是否答对
  */
 private Boolean right;
 /**
  * 这题答的时长
  */
 private Long duration;
 /**
  * 这题的得分
  */
 private Long points;
 ...

dataId 用于将这个问题同一个业务数据绑定, dataType 用来标志这个业务数据的类型,这两个字段方便数据的扩展; dataTitle 是业务数据的标题; options 是这个问题的选项; analysis 问题的解析,用于用户答题结束后的自查; right 用来记录问题的正确与否。

新增问题

上层接口

提供新增问题的接口:

@PostMapping("/saveOrUpdateQuestion")
public JsonData saveOrUpdateQuestion(@RequestBody Question data) {
 questionService.saveOrUpdateQuestion(data);
 return JsonData.success();
}

QuestionService:

public void saveOrUpdateQuestion(Question data) {
 if (StringUtils.isEmpty(data.getId())) {// 新增
  writer.insert(manager.getExamDataBase(), ExamConstant.QUESTION_COLLECT, data);
 } else {//修改
  writer.updateDocument(data, ExamConstant.QUESTION_COLLECT);
 }
}

DAO

Writer:

public void insert(String dataBase, String collect, MongoBean data) {
 if (data.getId() == null) {
  data.setId(BsonTool.uuid());
 }
 MongoCollection<Document> collection = getCollection(dataBase, collect);
 collection.insertOne(Document.parse(JSONObject.toJSONString(data)));
}

public Document updateDocument(MongoBean data, String questionCollect) {
 Document filter = new Document();
 filter.put("id", data.getId());
 Document res = new Document();
 res.put("$set", BsonDocument.parse(JSONObject.toJSONString(data)));
 update(manager.getExamDataBase(), questionCollect, filter, res);
 return res;
}
public boolean update(String dataBase, String collect, Bson filter, Bson update) {
 MongoCollection<Document> collection = getCollection(dataBase, collect);
 UpdateResult ur = collection.updateOne(filter, update);
 return ur.getModifiedCount() > 0;
}

阅读剩余部分

相关阅读 >>

mongodb集合中的文档管理

mongodb �c 使用模式构建之属性模式

mongodb数据库索引快速入门指南

mongodb常用数据类型分享

mongodb �c 使用模式构建之多态模式

如何在mongodb中创建和删除数据库

mongodb基本操作与python连接mongodb并进行基础操作的方法

springboot系列之mongodbaggregations用法详解

mongodb 3.0+安全权限访问控制详解

windows下mongodb的下载安装、环境配置教程图解

更多相关阅读请进入《mongodb》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...