方法一:通过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 所有可以打印的字符
文章评论