小程序答题系统随机答题的实现

  小程序答题系统随机答题的实现

  问答答题小程序的开发掀起了一股热潮,我们在开发微信小程序答题系统,需要实现随机出题。尤其是一些比如闯关的环节,需要随机从题库里抽取若干道题目,给到用户答题。那么要如何来做呢?

  首先我们要做两张表,一张是exam表,用来存考卷的。另外一张是题库表,question表。

  在exam表里设置好考试的参数,比如说本次考试是随机抽多少题,然后在sql语句中,随机从question表中抽取题目。

  注意了,划重点了,一些关键点来了。

  随机抽题目,一般人想到的是sql语句的 order by rand ,然后网上你搜下 order by rand语句的优化,也有人提到过,这个order by rand 执行效率很低。尤其是比如你的题库很大,如果你做大平台的,一定会在后期发生的。我们自己是做平台的,开发好这套系统是要不断的复制卖给所有的需要的客户的。所以客户出的题目肯定会越来越多,题库要越赖越大的。题库随着考试次数增多,题库将会变的非常大。所以提前就要想好解决办法,一次性把代码写到位。

  小程序答题系统 小程序答题

  使用ORDER BY RAND 一个15万余条的库,查询5条数据,居然要8秒以上。查看官方手册,也说rand()放在ORDER BY 子句中会被执行多次,自然效率及很低。

  怎么优化方法很多,大家自行百度,我用的是使用sql语句 limit的偏移量来做的。

  话不多说,直接上代码了。tp的风格哈。

小程序答题系统随机答题的实现

 $total=$questionTable->where($search)->count(); //查看下对应的题目总数有多少

  if($total<=$getrand_Num){ //总的题目数比需要的还小 那就不用随机了 直接出全部的题目就行了

  $offset = 0;

  }else{

  $offset = mt_rand(0, $total-1); //偏移量

  }

  $list=$questionTable->where($search)->field($field)->limit($offset,$getrand_Num)->select();

  不知道各位看懂了没有,这个偏移量的,就是使用这个模式来随机抽取题目。希望你也按照这个思路优化下你的考试答题系统的随机出题逻辑。

小程序工具提供多类型商城/门店小程序制作,可视化编辑 1秒生成5步上线。通过拖拽、拼接模块布局小程序商城页面,所看即所得,只需要美工就能做出精美商城。

有关进一步了解小程序开发案例,请前往:https://www.kesion.com/miniprogramdev/ 

【本站声明】
  1、本站文章中所选用的图片及文字来源于网络以及用户投稿,由于未联系到知识产权人或未发现有关知识产权的登记,如有知识产权人并不愿意我们使用,如果有侵权请立即联系。
  2、本网站不对文章中所涉及的内容真实性、准确性、可靠性负责,仅系客观性描述,如您需要了解该类商品/服务详细的资讯,请您直接与该类商品/服务的提供者联系。


KESION 科汛软件

KESION 科汛软件是国内领先的在线教育软件及私域社交电商软件服务提供商,长期专注于为企业提供在线教育软件及社交电商SaaS平台解决方案。
公司核心产品云开店SaaS社交电商服务平台、在线教育SaaS服务平台、教育企业数字化SaaS云平台、企微营销助手、私有化独立部署品牌网校和在线教育咨询等。

KESION 不断通过技术创新,提供产品和服务,助力企业向数字化转型,通过科技驱动商业革新,让商业变得更智慧!



▼点击进入科汛官网了解更多



热门标签
微信小程序 SaaS
上/下篇
  • 微信小程序搜索输入框带搜索记录

  • 教育类小程序系统开发特点

换一换相关推荐
精选内容
热点精选