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

最近在作接口测试的时候,测试数据是从数据库查询的,可是当须要并发屡次去调用接口时,若是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;

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

相关文章
相关标签/搜索