ORACLE随机查询n条记录

2013/10/09 2710点热度 0人点赞 0条评论

方法一:通过dbms_random.random

select * from (select * from your_table order by dbms_random.random) where rownum < 1000;

方法二:通过dbms_random.value

select * from (select * from your_table order by dbms_random.value) where rownum < 1000;

方法三:通过采样表扫描

select * from (select * from your_table sample(20)) where rownum < 1000;

三种方法执行效率:

方法三 > 方法一 > 方法二

主要注意以下几点:

1.sample只对单表生效,不能用于表连接和远程表

2.sample会使SQL自动使用CBO

3.sample是抽样查询,sample(20)意思是从总数中抽样20%,如果总数量比较小的话,甚至拿不到数据

 比如: 如果有10条数据,写上面的语句,最后只是找到0条

如果有100条数据,最后只能拿到20条,

不能做到总数小于1000条的时候把数据全部拿到

Order by dbms_random.random 和 order by dbms_random.value的作用和区别

 1)Order By dbms_random.value ,为结果集的每一行计算一个随机数,dbms_random.value 是结果集的一个列(虽然这个列并不在select list 中),然后根据该列排序,得到的顺序自然就是随机的

 2)value返回的是number类型,并且返回的值介于0和1之间,而random返回的是BINARY_INTEGER类型(以二进制形式存储的数字,据说运算的效率高于number但我没测试过,但取值范围肯定小于number,具体限制得查资料了)

  如果你要实现随机排序,还是用value函数吧

dbms_random.value() 用于返回两个数值之间的随机数,value(low,high)

  DBMS_RANDOM.VALUE()  默认是从0到1间的数

select dbms_random.value() from dual;

值 0.0536824248407651

select dbms_random.value(10,100) from dual;

值  29.2420951206225

dbms_random.random() 返回的值介于2的31次方和-2的31次方之间的整形数值

select dbms_random.random() from dual;

值  2071097056

dbms_random.string('parameter',length)

select dbms_random.string('a',10) from dual;     --all返回不分大小写的字母字符串
select dbms_random.string('u',10) from dual;   --upper返回大写字母字符串
select dbms_random.string('l',10) from dual;  --little小写字母
select dbms_random.string('x',10) from dual;   ---大写字母加数字
select dbms_random.string('p',10) from dual;  --print 所有可以打印的字符

 

yxkong

这个人很懒,什么都没留下

文章评论