一个简单的问卷调查服务端设计

最近遇到个需求需要设计个问卷调查,包括发布问卷、选择题型、提交问卷、统计选择题的选项概率,所以就简单设计了下。(备注:无题库概念)

1、数据库设计

     问卷信息表

DROP TABLE IF EXISTS `t_survey_info`;
CREATE TABLE `t_survey_info` (
  `id` bigint(30) NOT NULL AUTO_INCREMENT,
  `title` varchar(255) DEFAULT NULL COMMENT '标题',
  `description` longtext COMMENT '描述',
  `is_read_only` varchar(1) DEFAULT NULL COMMENT '是否只读 1 是 0 否',
  `del_flag` varchar(255) DEFAULT NULL COMMENT '是否有效 0 否 1 是',
  `is_load` varchar(1) DEFAULT NULL COMMENT '上下架 0 否 1 是',
  `operate_time` datetime DEFAULT NULL COMMENT '操作时间',
  `operate_user` varchar(255) DEFAULT NULL COMMENT '操作用户',
  `begin_time` varchar(100) DEFAULT NULL COMMENT '开始时间',
  `end_time` varchar(100) DEFAULT NULL COMMENT '结束时间',
  `link_url` varchar(255) DEFAULT NULL COMMENT '问卷地址',
  `link_key` varchar(255) DEFAULT NULL COMMENT '问卷key',
  PRIMARY KEY (`id`) USING BTREE,
  KEY `INDEX_LINK_KEY` (`link_key`)
) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8mb4 ROW_FORMAT=DYNAMIC COMMENT='问卷信息表';

问卷题目表

DROP TABLE IF EXISTS `t_survey_question`;
CREATE TABLE `t_survey_question` (
  `id` bigint(30) NOT NULL AUTO_INCREMENT,
  `question_title` varchar(255) DEFAULT NULL COMMENT '问题标题',
  `question_type` varchar(255) DEFAULT NULL COMMENT '问题类别(单选 多选  问答)',
  `question_content` longtext COMMENT '问题内容(单选 多选)',
  `operate_time` datetime DEFAULT NULL COMMENT '操作时间',
  `operate_user` varchar(255) DEFAULT NULL COMMENT '操作用户',
  `del_flag` varchar(1) DEFAULT NULL COMMENT '是否有效 0 否 1 是',
  `is_load` varchar(1) DEFAULT NULL COMMENT '上下架 0 否 1 是',
  `is_required` varchar(1) DEFAULT NULL COMMENT '是否必填 0 否 1 是',
  `survey_id` bigint(30) DEFAULT NULL COMMENT '问卷Id',
  `order_sort` int(10) DEFAULT NULL COMMENT '排序字段',
  `total_num` int(10) DEFAULT NULL COMMENT '数量',
  PRIMARY KEY (`id`) USING BTREE,
  KEY `INDEX_SURVEY_ID` (`survey_id`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=103 DEFAULT CHARSET=utf8mb4 ROW_FORMAT=DYNAMIC COMMENT='问卷问题表';   

问卷题目选项表

 DROP TABLE IF EXISTS `t_survey_item`;
CREATE TABLE `t_survey_item` (
  `id` bigint(30) NOT NULL AUTO_INCREMENT,
  `question_id` bigint(30) DEFAULT NULL COMMENT '问题Id',
  `survey_id` bigint(30) DEFAULT NULL COMMENT '问卷ID',
  `total_num` int(20) DEFAULT NULL COMMENT '总数量',
  `question_type` varchar(100) DEFAULT NULL COMMENT '问题类别',
  `choice_content` varchar(100) DEFAULT NULL COMMENT '选择内容',
  `percent_num` varchar(20) DEFAULT NULL COMMENT '百分比',
  `choice_key` varchar(100) DEFAULT NULL COMMENT '内容key',
  PRIMARY KEY (`id`) USING BTREE,
  KEY `INDEX_QUESTION_ID` (`question_id`) USING BTREE,
  KEY `INDEX_SURVEY_ID` (`survey_id`) USING BTREE,
  KEY `INDEX_CHOICE_INDEX` (`choice_content`,`question_type`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=160 DEFAULT CHARSET=utf8mb4 ROW_FORMAT=DYNAMIC COMMENT='问卷题目选项表';

问卷答案表

DROP TABLE IF EXISTS `t_survey_answer`;
CREATE TABLE `t_survey_answer` (
  `id` bigint(30) NOT NULL AUTO_INCREMENT,
  `question_id` bigint(30) DEFAULT NULL COMMENT '问题Id',
  `survey_id` bigint(30) DEFAULT NULL COMMENT '问卷ID',
  `choice_content` varchar(3000) DEFAULT NULL COMMENT '选择(填写内容)',
  `user_id` varchar(30) DEFAULT NULL COMMENT '用户ID',
  `user_name` varchar(255) DEFAULT NULL COMMENT '用户名称',
  `operate_time` datetime DEFAULT NULL COMMENT '操作时间',
  `question_type` varchar(255) DEFAULT NULL COMMENT '问题类别',
  `phone` varchar(100) DEFAULT NULL COMMENT '手机号',
  PRIMARY KEY (`id`) USING BTREE,
  UNIQUE KEY `INDEX_QUESTION_ID` (`question_id`,`survey_id`,`user_id`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=41 DEFAULT CHARSET=utf8mb4 ROW_FORMAT=DYNAMIC COMMENT='问卷答案表';

2、关键逻辑点

    获取问卷信息频繁,增加缓存

    问卷重复提交,利用redis  increment以及前端置灰色

    每个选项数量+1 ,异步线程

3、代码展示

     管理后台+接口,代码不上传,需自己实现!

    

      

 

 

                                                                            

  1、添加、修改、删除、预览问卷、问卷题目   2、模板管理:修改,添加,设置默认,删除等功能   3、前台调用问卷页面   4、前台调用问卷结果   5问卷调查题目可以导出、导入   6、可以设置生成静态或动态页面   7、对用户填写的问卷数据进行有效性验证   8、后台以柱形图、列表式、卡片式以及普通的方式来显示调查结果   9、后台可以选择“开启”或“关闭”是否要求只有会员才能投票   10、可以设置是否允许同一IP重复提交   11、可以给问卷设置密码,只有密码正确才能提交问卷   12、可以给问卷设置来访IP限定,即黑、白名单功能。   13、给问卷设置结束日期   14、每个问卷可以设置自己的模板   15、问卷页面创建后,可以进行编辑和预览。   16、后台搜索功能,包括对:问卷列表、题目列表、单个问卷题目列表等的搜索   17、可以查看问卷中某问题,每个用户所填的内容。   18、生成的表单可以根据题目类型判断,文字区域或文本框给个字段控制内容大小。在提交和生成表单的时候同时也做js判断。   19、问卷报表和打印功能   20、扩展功能,做成酒店预订,在线报名等。   21、允许提交表单的页面列表。只允许特定页面的表单提交,从其他页面提交过来的数据都认为是非法的地址。这样可以防止其他人另外伪造表单在自己的网站上提交数据。   22、对注册会员的参与者可以设置点数奖励。   注意:因为目前的版本是测试版,数据结构等还没有完全稳定,并且我们不提供从测试版到正式版的数据升级程序,所以请大家仅用于测试,不要用于正式调查。另外,测试版有使用时间限制,只能在2006年12月31日前使用。请您不要用于正式场合。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值