浏览 5229 次
锁定老帖子 主题:使用Rails怎么写这个查询?
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2007-05-01
我先作了题库,我希望能够从题库中随机选择一定数目的题,并生成一份试卷。 在随机选择一定数目的题的地方没有找到比较好的方式: Rails好像没有提供存储过程的操作接口。 试题由于删除等原因,id是不连续的。 我现在想到的方式有两种: 1)将所有题目的id查询出来放在一个数组中,然后产生若干个随机数并去掉 重复元素作为数组,从而选定题目,然后拼接sql语句进行查询,这样的缺点是查询所有数目 的试题id放在数组中,如果数目过多,这样做很耗内存.(当然可以通过limit来 限制数量,但数据库默认会建立索引,查询的时候会按照某种顺序列出,后面的题 就没有被选的机会了) 2)先查出题目的数目n,然后在1..n之间生成一定数目的随机数,作为题目id,如果查询到的 题目数目不够,再随机生成随机数,再查询生成,直到查询到足够的题目为止,这样 做缺点是每一步生成随机数还得以前的随机数去除重复,并且查询次数未知. 希望大家能给我一个解决这个问题的更好的方案. 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间: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 随机"作关键字,找出一大堆结果。。。 |
|
返回顶楼 | |
发表时间: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 随机"那么好的关键词,没搜到什么答案。 |
|
返回顶楼 | |