SQL语句 随机读取N条记录

利用一条SQL语句从数据库Table表中随机获取N条记录,各数据库的SQL语句略有不同,如下:

1、MySql

1 Select* FromTABLEOrderByRand() Limit N

以上代码效率不高,自己对1000条数据表随机取10条的测试结果为耗时0.125s,有网友推荐改为以下代码效率有大幅提高,耗时为0.005s,不过结果是随机从某个位置开始取N条记录,而不是随机取N条记录,略有差异。详细说明见mysql使用rand随机查询记录效率测试。

2 SELECT* FROM`TABLE` a join(SELECTROUND(RAND() * ((SELECTMAX(id) FROM`TABLE`)-(SELECTMIN(id) FROM`TABLE`))+(SELECTMIN

(id) FROM`TABLE`)) ASid) ASb WHEREa.id >= b.id ORDERBYa.id LIMIT N;
 

2、SQL Server

1 SelectTOPN * FromTABLEOrderByNewID()


NewID()函数将创建一个 uniqueidentifier 类型的唯一值。

3、Access

1 SelectTOPN * FromTABLEOrderByRnd(ID)

Rnd(ID) 其中的ID是自动编号字段,可以利用其他任何数值来完成,比如用姓名字段(UserName)

2 SelectTOPN * FromTABLEOrderBYRnd(Len(UserName))

4、Oracle

1)dbms_random包

1 select* from(select* fromTableorderbydbms_random.value) whererownum < N;

注:dbms_random包需要手工安装,位于$ORACLE_HOME/rdbms/admin/dbmsrand.sql

2 dbms_random.value(100,200)

可以产生100到200范围的随机数

2)按概率抽取:

1 select* fromTablesample(百分比);

3)sys_guid

1 select* from(select* fromTableorderby   sys_guid()) whererownum<N;

5、postgreSQL

1 select* fromTableorderbyrandom() limit N

 

 

 

 

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;

猜你喜欢

转载自starbhhc.iteye.com/blog/1387698
今日推荐