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

我是先提取这500题放入数组,然后打乱数组,然后存入一个新的数据表内,再一题一题的读取出来给学员练习! 但是整个读取>打乱>写入的过程很慢!

php里面有array_rand函数,你要是一道题一道题的读出来,或许也可以尝试一下。但是要是一下子都读出来,即便这个函数效率可以的话,随机取出id数组,查询 “where id in 数组” 就不如直接在数据库里随机抽取记录。
如何从数据表里随机抽取记录呢,想想办法还是有一些,就是不知道效率如何。有的是说用max_id*rand(),那一条一条抽取还是可以的。怎么批量随机抽取呢,可以试着排序,然后选取前500题,排序可以想办法用一些函数(选取一些执行效率高的),如何md5,sha1,这种。如果为了使结果更具有随机性,可以把字段值再与一个随机数运算一下。仅供参考。
========================
我想你还是用array_rand随机抽500个id存到数组,然后遍历数组吧。这样也避免了题目重复。在数据库里如果一次一条记录随机抽取,要考虑碰巧重复的问题。批量选取你就按上面我说的试试。
温馨提示:答案为网友推荐,仅供参考
第1个回答  2013-05-17
step1:10000道题目存入题库,编号1~·10000
step2:每个考生登录时,随机产生500个1~10000的不重复随机数,存入该考生登录信息里,
step3:依次读取500个随机数所对应的题目显示给考生。并把考生的答案和随机数同时存储。
第2个回答  2013-05-17
用mysql,RAND函数 (注意写的效率点)
第3个回答  2013-05-17
运用SQL随机查询吧,这样效率要高些
相似回答