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

Posted 纭卿殇

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql 随机获取一条或多条数据相关的知识,希望对你有一定的参考价值。

若要在i ≤r≤ j 这个范围得到一个随机整数r ,需要用到表达式 FLOOR( RAND() * (j – i)+i),RLOOR()取整树部分,RAND()、ROUND(x,n)四舍五入取整,ROUND(x,n)表示随机生成一个 0~x 之间的n位小数的数字

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

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

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 user 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 user AS U2) ) +(SELECT MIN(U3.userid) FROM users AS U3)) 

ORDER BY users.userid ASC 

LIMIT 1

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

 

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

 

以上是关于mysql 随机获取一条或多条数据的主要内容,如果未能解决你的问题,请参考以下文章

MySQL实现随机获取几条数据的方法

java中怎么一次性向表中插入一条或多条数据

使用 NodeJS 在 mySQL 中插入多条记录以防止注入并获取每条记录的 ID

对选定的数组记录运行更新

EasyUI treegrid 删除一条或多条记录

MySql实现随机获取表中的一条数据