mysql使用——sql实现随机取一条数据
最近在做接口测试的时候,测试数据是从数据库查询的,但是当需要并发多次去调用接口时,如果sql只是单纯的进行了limit取值,那并发的时候肯定会每条数据都一样。
因此,研究了下sql随机取一条数据的写法,从而用大量不同数据去进行并发的接口性能测试
原文:
三种方法:
(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;
此种写法的效率是介于前面两种之间