使用Rails怎样写这个查询?
当前位置:首页 ----> Web开发 ----> Ruby/Python
关键词:Rails,id,sql,limit
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 随机"那么好的关键词,没搜到什麽答案。
原文出处:http://www.javaeye.com/topic/76516