In the past, I used to directly order by rand() to handle this kind of usage scenario, but the efficiency was really not satisfactory. So I encountered this scenario again recently and looked for a better solution online. 1.order by rand() Writing method: SELECT id FROM `table` ORDER BY rand() The disadvantage of this writing method is that the rand function is executed multiple times in the order by, affecting efficiency. 2. max(id) * rand() using join Writing method: SELECT * FROM `table` AS t1 JOIN ( SELECT ROUND( RAND() * ( (SELECT MAX(id) FROM `table`) - (SELECT MIN(id) FROM `table`) ) + (SELECT MIN(id) FROM `table`) ) AS id ) AS t2 WHERE t1.id >= t2.id ORDER BY t1.id LIMIT 1; The big guys on the Internet all recommend the second way of writing, so I'd like to record it down. I feel that the maximum id and the minimum id can be calculated in the program. The problem here is that if you take multiple records, they must be continuous, so if you don't want to take continuous data, you have to loop. However, this statement is extremely efficient, so loop query can be done. The above are all the relevant knowledge points. Friends in need can learn from them. Thank you for your support of 123WORDPRESS.COM. |
<<: Element sample code to implement dynamic table
>>: How to install babel using npm in vscode
The link-in style is to put all the styles in one...
[Problem description] On the application side, th...
Overview of MySQL Partitioned Tables As MySQL bec...
Table of contents 1. Document.execCommand() metho...
First method Alibaba Cloud and Baidu Cloud server...
The /etc/network/interfaces file in Linux is used...
1. Unzip the downloaded MySQL compressed package ...
This article describes the steps to install the p...
Table of contents Preface toDoList just do it Pre...
There is currently a requirement that an operatio...
Create a Directory cd /usr/local/docker/ mkdir je...
illustrate: VMware IOInsight is a tool that helps...
The basic principle of all animations is to displ...
This article example shares the specific code of ...
1.Jenkins installation steps: https://www.jb51.ne...