mysql使用——sql实现随机取一条数据

最近在做接口测试的时候,测试数据是从数据库查询的,但是当需要并发多次去调用接口时,如果sql只是单纯的进行了limit取值,那并发的时候肯定会每条数据都一样。

因此,研究了下sql随机取一条数据的写法,从而用大量不同数据去进行并发的接口性能测试

原文:https://www.cnblogs.com/my_life/articles/7827233.html

三种方法:

(1)ORDER BY RAND()

写法:SELECT * FROM 表A ORDER BY RAND() LIMIT 1

缺点:rand()放在ORDER BY 子句中会被执行多次,自然效率极低,mysql官方不提倡

(2)max(id) * rand()   +   join

写法:select id from table 表A join (select round(rand()*(select max(id ) from table)) as idd) as 表B on 表A.id>表B.idd limit 1;

百度了很多,大佬们都认为采用JOIN的语法是最优的

(3)max(id) * rand()   

写法:SELECT * FROM 表A  WHERE id >= (SELECT FLOOR( MAX(id) * RAND()) FROM 表A ) ORDER BY id LIMIT 1;

此种写法的效率是介于前面两种之间

 

猜你喜欢

转载自www.cnblogs.com/muzipaopao/p/11104201.html