论坛首页 编程语言技术论坛

使用Rails怎么写这个查询?

浏览 5229 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2007-05-01  
我做一个在线考试系统。
我先作了题库,我希望能够从题库中随机选择一定数目的题,并生成一份试卷。
在随机选择一定数目的题的地方没有找到比较好的方式:
Rails好像没有提供存储过程的操作接口。
试题由于删除等原因,id是不连续的。
我现在想到的方式有两种:
1)将所有题目的id查询出来放在一个数组中,然后产生若干个随机数并去掉
重复元素作为数组,从而选定题目,然后拼接sql语句进行查询,这样的缺点是查询所有数目
的试题id放在数组中,如果数目过多,这样做很耗内存.(当然可以通过limit来
限制数量,但数据库默认会建立索引,查询的时候会按照某种顺序列出,后面的题
就没有被选的机会了)
2)先查出题目的数目n,然后在1..n之间生成一定数目的随机数,作为题目id,如果查询到的
题目数目不够,再随机生成随机数,再查询生成,直到查询到足够的题目为止,这样
做缺点是每一步生成随机数还得以前的随机数去除重复,并且查询次数未知.

希望大家能给我一个解决这个问题的更好的方案.
   发表时间: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 随机"作关键字,找出一大堆结果。。。
0 请登录后投票
   发表时间: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 随机"那么好的关键词,没搜到什么答案。
0 请登录后投票
论坛首页 编程语言技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics