php mysql随机取一条数据_mysql 随机获取一条或多条数据

若要在i ≤r≤ j 这个范围得到一个随机整数r ,需要用到表达式 FLOOR( RAND() * (j – i)+i),RLOOR()取整树部分,RAND()生成0~1的随机数、ROUND(x,n)四舍五入取整,ROUND(x,n)表示四舍五入返回数字x的n位小数的数字,n可以是负数,这时是指定小数点左边的n位整数位为0,同时小数位均为0;。

例如, 若要在7 到 12 的范围(包括7和12)内得到一个随机整数, 可使用以下语句:

SELECT  FLOOR(RAND()*(12-7)+7)

如:3.434561和3.2452 保留2位小数取值

round(3.434561, 2) = 3.43;

round(3.2452, 2) = 3.25;

round(1113.2452, -2) = 1100;

从 Mysql 表中随机读取数据不难,方法还挺多的,但是如果要考虑效率,得到一个快速的高效率的方法。

随机获得Mysql数据表的一条或多条记录有很多方法,下面以users(userId,userName,password……)表,百多万条以上记录为例:

1、常规使用方法

SELECT * FROM  users  ORDER BY RAND() LIMIT 1

结论:效率最慢,在 ORDER BY从句里面不能使用RAND()函数,因为这样会导致数据列被多次扫描,导致效率相当相当的低!

2、SELECT * FROM users AS U0

JOIN

(SELECT FLOOR( RAND()*((SELECT MAX(U1.userid) FROM users AS U1)-(SELECT MIN(U2.userid) FROM users AS U2) ) +(SELECT MIN(U3.userid) FROM users AS U3)) AS userid ) AS U4

ON U0.userid>= U4.userid

LIMIT 1

结论:随机一条数据效率还行,多条就不行

3、通过sql获得最大值和最小值,然后通过php的rand生成一个随机数randnum,再通过SELECT * FROM users WHERE userId >= randnum LIMIT 1

SELECT * FROM users WHERE

users.userid>= FLOOR( RAND()*((SELECT MAX(U1.userid) FROM users AS U1)-(SELECT MIN(U2.userid) FROM users AS U2) ) +(SELECT MIN(U3.userid) FROM users AS U3))

ORDER BY users.userid ASC

LIMIT 1

结论:随机取一条或多条记录,方法都不错! (最佳方案)

附:field(column,value1,value2,value3,……) 代表根据column列自定义的顺序排

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值