您当前的位置: 首页 > 数据库教程 > MySQL教程 > 从mysql数据表中随机取出一条记录

从mysql数据表中随机取出一条记录

作者:不详 来源:网络 发布时间: 2014-07-17 11:57 点击:
当然最后我的一段代码有错误的,并不是真正意义上的随机取数据。回到家,赶快百度,这才知道了如何随机取数据.. 其余代码不多说,这里就告诉你这句核心查找数据表代码: 代码如下 select * from 表名 order by rand( ) limit 1; //此处的1就是取出数据的条数 但这样取

从mysql数据表中随机取出一条记录

  当然最后我的一段代码有错误的,并不是真正意义上的随机取数据。回到家,赶快百度,这才知道了如何随机取数据..

  其余代码不多说,这里就告诉你这句核心查找数据表代码:

  

  

  

  

  

  

  

  

  

  

  
代码如下


  select * from 表名 order by rand( ) limit 1; //此处的1就是取出数据的条数

  


  但这样取数据网上有人说效率非常差的,那么要如何改进呢

  搜索Google,网上基本上都是查询max(id) * rand()来随机获取数据。

  

  

  

  

  

  

  

  

  

  

  
代码如下


  SELECT *

  FROM `table` AS t1 JOIN (SELECT ROUND(RAND() * (SELECT MAX(id) FROM `table`)) AS id) AS t2

  WHERE t1.id >= t2.id

  ORDER BY t1.id ASC LIMIT 5;

  


  但是这样获得的是5条连续的记录。解决办法只能是每次查询一条,查询5次,但这个又不能满足我的要求了,我要一次找几条

  高效写法

  

  

  

  

  

  

  

  

  

  

  
代码如下


  SELECT * FROM user WHERE userId >= ((SELECT MAX(userId) FROM user )-(SELECT MIN(userId) FROM user )) * RAND() + (SELECT MIN(userId) FROM user ) LIMIT 5

  
分享到:
本文"从mysql数据表中随机取出一条记录"由远航站长收集整理而来,仅供大家学习与参考使用。更多网站制作教程尽在远航站长站。
顶一下
(0)
0%
踩一下
(0)
0%
[点击 次] [返回上一页] [打印]
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
用户名: 密码: 验证码:
关于本站 - 联系我们 - 网站声明 - 友情连接- 网站地图 - 站点地图 - 返回顶部
Copyright © 2007-2013 www.yhzhan.com(远航站长). All Rights Reserved .
远航站长:为中小站长提供最佳的学习与交流平台,提供网页制作与网站编程等各类网站制作教程.
官方QQ:445490277 网站群:26680406 网站备案号:豫ICP备07500620号-4