当前位置:首页 > 开发 > 数据库 > 正文

随机读取N条记录(MySQL、SQL Server、Access、Oracle、postgreSQL)|access

发表于: 2011-03-30   作者:cuijiemin   来源:转载   浏览:
摘要: 利用一条SQL语句从数据库Table表中随机获取N条记录,各数据库的SQL语句略有不同,如下:1、MySql Select*From TABLE Order By Rand()Limit N以上代码效率不高,自己对1000条数据表随机取10条的测试结果为耗时0.125s,有网友推荐改为以下代码效率有大幅提高,耗时为0.005s,不过结果是随机从某个位置开始取N条记录,而不是随机取N条记录,略有差异

利用一条SQL语句从数据库Table表中随机获取N条记录,各数据库的SQL语句略有不同,如下:
1、MySql Select*From TABLE Order By Rand()Limit N
以上代码效率不高,自己对1000条数据表随机取10条的测试结果为耗时0.125s,有网友推荐改为以下代码效率有大幅提高,耗时为0.005s,不过结果是随机从某个位置开始取N条记录,而不是随机取N条记录,略有差异。详细说明见mysql使用rand随机查询记录效率测试。
SELECT*FROM`TABLE`ajoin(SELECT ROUND(RAND()*((SELECT MAX(id)FROM`TABLE`)-(SELECT MIN(id)FROM`TABLE`)) (SELECT MIN(id)FROM`TABLE`))AS id)AS bWHERE a.id=b.idORDER BY a.id LIMIT N;
2、SQL Server Select TOP N*From TABLE Order By NewID()NewID()函数将创建一个uniqueidentifier类型的唯一值。
3、Access Select TOP N*From TABLE Order By Rnd(ID)
Rnd(ID)其中的ID是自动编号字段,可以利用其他任何数值来完成,比如用姓名字段(UserName)
Select TOP N*From TABLE Order BY Rnd(Len(UserName))
4、Oracle 1)dbms_random包
select*from(select*from Table order by dbms_random.value)where rownum N;
注:dbms_random包需要手工安装,位于$ORACLE_HOME/rdbms/admin/dbmsrand.sql dbms_random.value(100,200)
可以产生100到200范围的随机数
2)按概率抽取:
select*from Table sample(百分比);例:
select*from Table sample(10);取表Table中记录条数的10%条记录
3)sys_guid select*from(select*from Tableorderby sys_guid())whererownum N;
5、postgreSQL select*from Table order by random()limit N

随机读取N条记录(MySQL、SQL Server、Access、Oracle、postgreSQL)|access

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号