最近在作接口测试的时候,测试数据是从数据库查询的,可是当须要并发屡次去调用接口时,若是sql只是单纯的进行了limit取值,那并发的时候确定会每条数据都同样。html
所以,研究了下sql随机取一条数据的写法,从而用大量不一样数据去进行并发的接口性能测试mysql
原文:https://www.cnblogs.com/my_life/articles/7827233.htmlsql
三种方法:数据库
(1)ORDER BY RAND()并发
写法:SELECT * FROM 表A ORDER BY RAND() LIMIT 1性能
缺点:rand()放在ORDER BY 子句中会被执行屡次,天然效率极低,mysql官方不提倡测试
(2)max(id) * rand() + joinhtm
写法: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;blog
百度了不少,大佬们都认为采用JOIN的语法是最优的接口
(3)max(id) * rand()
写法:SELECT * FROM 表A WHERE id >= (SELECT FLOOR( MAX(id) * RAND()) FROM 表A ) ORDER BY id LIMIT 1;
此种写法的效率是介于前面两种之间