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

- 来自: 长春

- 详细资料
搜索本博客
我的相册
RSS Reader1
共 6 张
共 6 张
链接
最新评论
-
写了一个支持搜索并下载歌 ...
引用 为什么要配置成legal_music_link=http://202.10 ...
-- by fuliang -
使用Struts2+Hibernate+Sp ...
很好很强大
-- by andy54321 -
Java Persistence with Hi ...
昨天买的, 不错
-- by lklkdawei -
使用Struts2+Spring+Hiber ...
不过整个工程都没有一条注释啊。。。 这个比较郁闷,万一以后你写了个框架,那下面 ...
-- by yyphzc -
使用Struts2+Spring+Hiber ...
总体感觉还行,不过部分代码需要优化为好 1.DAO既然使用泛型,那就干脆点。想想 ...
-- by yeshucheng






评论排行榜