fuliang: 相关文章: X
数据库对象的缓存策略
关於分页查询的疑惑
<img src=http://www.javaeye.com/images/icon_more.gif/>
我做一个在线考试系统。
我先作了题库,我希望能够从题库中随机选择一定数目的题,并生成一份试卷。
在随机选择一定数目的题的地方没有找到比较好的方式:
Rails好象没有提供存储过程的操作接口。
试题由于删除等原因,id是不连续的。
我现在想到的方式有两种:
1)将所有题目的id查询出来放在一个数组中,然后产生若干个随机数并去掉
重复元素作为数组,从而选定题目,然后拼接sql语句进行查询,这样的缺点是查询所有数目
的试题id放在数组中,假如数目过多,这样做很耗内存.(当然可以通过limit来
限制数量,但数据库默认会建立索引,查询的时候会按照某种顺序列出,后面的题
就没有被选的机会了)
2)先查出题目的数目n,然后在1..n之间生成一定数目的随机数,作为题目id,假如查询到的
题目数目不够,再随机生成随机数,再查询生成,直到查询到足够的题目为止,这样
做缺点是每一步生成随机数还得以前的随机数去除重复,并且查询次数未知.
希望大家能给我一个解决这个问题的更好的方案. qiezi: 搜了一个:mysql: select * from tablename order by rand() limit 10sqlserver: select top 10 * from tablename order by NEWID()不知道是否可行。效率可能不高,这种排序方式应当会相起全表扫描,有多少条记录就会调用多少次取随机数。这里搜到一个优化版本:http://www.kingmx.com/article/11487我都没有做过测试,这种问题还是自己google吧,我用"select 随机"作关键字,找出一大堆结果。。。 fuliang: 引用搜了一个:mysql: select * from tablename order by rand() limit 10sqlserver: select top 10 * from tablename order by NEWID()不知道是否可行。效率可能不高,这种排序方式应当会相起全表扫描,有多少条记录就会调用多少次取随机数。这里搜到一个优化版本:http://www.kingmx.com/article/11487我都没有做过测试,这种问题还是自己google吧,我用"select 随机"作关键字,找出一大堆结果。。。感谢了,没想到还有这么一个技巧,我也到google上搜了,不过没找到像您说的"select 随机"那么好的关键词,没搜到什麽答案。