探索测试之路。。。

sql,oracle获取随机记录方法

上一篇 / 下一篇  2008-05-30 09:58:17 / 个人分类:数据库

sql里面:
比如读取10条随机记录
select top 10 * from tablename order by newid();

Oracle里面:
1.dbms_random包
select * from (select * from tablename order by dbms_random.value) where rownum < N;
例:
select * from (select * from tablename order by dbms_random.value) where rownum < 3;
注:dbms_random包需要手工安装,位于$ORACLE_HOME/rdbms/admin/dbmsrand.sql
dbms_random.value(100,200)可以产生100到200范围的随机数
2.按概率抽取:
select * from tablename sample(百分比);
例:
select * from tablename sample(10);
3.sys_guid
select * from (select * from tablename orderby   sys_guid()) where rownum<10;


TAG: 数据库

 

评分:0

我来说两句

Open Toolbar