投稿或申请专栏请先 [ 登 陆 ] 新版进入 旧版进入
您的位置: 首页>数据库>MySQL>正文
站内搜索
    
最新论文TOP10
·保持共产党员先进性教育心得体会
·工商局2006年度工作计划
·县交通局党委2006年工作计划
·医院工会工作总结
·2005年度医院护理工作总结
·2006年护理工作计划
·2006年度保险公司工作计划
·公路局工会副主任个人工作总结
·公路局助理工程师个人业务工作总
·市地税局1—10月份工作总结
热点论文TOP10

·小学数学论文的撰写
·毕业论文范文
·年度个人述职报告
·毛泽东思想概论心得
·寒假社会调查报告
·开题报告范文
·寒假社会调查报告
·寒假社会实践调查报告
·计算机毕业论文
·述职报告

相关论文TOP10

MySQL 如何从表中取出随机数据

作者:佚名    来源:网络    时间:2005-12-9 10:13:48  浏览:

以前在群里讨论过这个问题,比较的有意思.mysql的语法真好玩.他们原来都想用PHP的实现随机,但取出多条好像要进行两次以上查询.翻了手册,找到了下面这个语句,可以完成任务了
SELECT * FROM table_name ORDER BY rand() LIMIT 5;
rand在手册里是这么说的:
RAND() 
RAND(N) 
返回在范围0到1.0内的随机浮点值。如果一个整数参数N被指定,它被用作种子值。 
mysql> select RAND();
        -> 0.5925
mysql> select RAND(20);
        -> 0.1811
mysql> select RAND(20);
        -> 0.1811
mysql> select RAND();
        -> 0.2079
mysql> select RAND();
        -> 0.7888
你不能在一个ORDER BY子句用RAND()值使用列,因为ORDER BY将重复计算列多次。然而在MySQL3.23中,你可以做: SELECT * FROM table_name ORDER BY RAND(),这是有利于得到一个来自SELECT * FROM table1,table2 WHERE a=b AND c<d ORDER BY RAND() LIMIT 1000的集合的随机样本。注意在一个WHERE子句里的一个RAND()将在每次WHERE被执行时重新评估。 
但我试了一下,8千条记录的表,执行一次需要0.08 sec,.慢了些
后来请教了google,得到如下代码
SELECT *
  FROM table_name AS r1 JOIN 
       (SELECT ROUND(RAND() * 
                     (SELECT MAX(id) 
                        FROM table_name)) AS id)
        AS r2 
 WHERE r1.id >= r2.id 
 ORDER BY r1.id ASC 
 LIMIT 5;
执行效率需要0.02 sec.可惜的是,只有mysql 4.1.*以上才支持这样的子查询.
首席范文网版权与免责声明:

 
凡本网注明“来源:范文123网(范文网123)”的所有作品,版权均属于范文123网(范文网123),未经本网授权不得转载、摘编或利用其它方式使用上述作品。已经本网授权使用作品的,应在授权范围内使用,并注明“来源:范文123网”。违反上述声明者,本网将追究其相关法律责任。
凡本网注明“来源:XXX(非范文123网)”的作品,均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。
如因作品内容、版权和其它问题需要同本网联系的,请在30日内进行。