用php+mysql做一个题库系统,上万题内随机抽取五百题左右生成考试卷,求最有效率的做法! 10

我是先提取这500题放入数组,然后打乱数组,然后存入一个新的数据表内,再一题一题的读取出来给学员练习!但是整个读取>打乱>写入的过程很慢!... 我是先提取这500题放入数组,然后打乱数组,然后存入一个新的数据表内,再一题一题的读取出来给学员练习! 但是整个读取>打乱>写入的过程很慢! 展开
 我来答
TheThinKing
2013-05-17 · TA获得超过552个赞
知道小有建树答主
回答量:599
采纳率:100%
帮助的人:471万
展开全部
php里面有array_rand函数,你要是一道题一道题的读出来,或许也可以尝试一下。但是要是一下子都读出来,即便这个函数效率可以的话,随机取出id数组,查询 “where id in 数组” 就不如直接在数据库里随机抽取记录。
如何从数据表里随机抽取记录呢,想想办法还是有一些,就是不知道效率如何。有的是说用max_id*rand(),那一条一条抽取还是可以的。怎么批量随机抽取呢,可以试着排序,然后选取前500题,排序可以想办法用一些函数(选取一些执行效率高的),如何md5,sha1,这种。如果为了使结果更具有随机性,可以把字段值再与一个随机数运算一下。仅供参考。
========================
我想你还是用array_rand随机抽500个id存到数组,然后遍历数组吧。这样也避免了题目重复。在数据库里如果一次一条记录随机抽取,要考虑碰巧重复的问题。批量选取你就按上面我说的试试。
我爱家滋味
2013-05-17
知道答主
回答量:16
采纳率:0%
帮助的人:9.4万
展开全部
step1:10000道题目存入题库,编号1~·10000
step2:每个考生登录时,随机产生500个1~10000的不重复随机数,存入该考生登录信息里,
step3:依次读取500个随机数所对应的题目显示给考生。并把考生的答案和随机数同时存储。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
欢乐的尼美
2013-05-17 · TA获得超过220个赞
知道小有建树答主
回答量:294
采纳率:100%
帮助的人:174万
展开全部
用mysql,RAND函数 (注意写的效率点)
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
六原升耗车03
2013-05-17 · 超过28用户采纳过TA的回答
知道答主
回答量:430
采纳率:80%
帮助的人:43.9万
展开全部
运用SQL随机查询吧,这样效率要高些
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式