在本教程中,您将学习从MySQL的数据库表中选择随机记录的各种技术方法。有时我们需要从表中选择随机记录,例如:- 在博客中选择一些随机帖子,并在侧栏中显示。- 在“每日报价”窗口小部件中显示随机报价。- 在图库中选择随机图片,并作为特色图片。## MySQL使用ORDER BY RAND()选择随机记录MySQL没有内置语句来从数据库表中选择随机记录。为了实现这个目的,可使用RAND
函数。 以下查询是从数据库表中选择一个随机记录:sqlSELECT *FROM tblORDER BY RAND()LIMIT 1;
让我们详细地看看上面的查询语句。- RAND()
函数为表中的每一行生成一个随机值。- ORDER BY子句按照RAND()
函数生成的随机数对表中的所有行进行排序。- LIMIT子句选择随机排序的结果集中的第一行。如果要从数据库表中选择N
个随机记录,则需要修改LIMIT
子句后指定的值,如下所示:sqlSELECT *FROM tableORDER BY RAND()LIMIT N;
例如,要在customer
表中选择5
个随机客户,请使用以下查询:sqlSELECT t.customer_id, t.customer_nameFROM studymysql.customer AS tORDER BY RAND()LIMIT 5;
执行上面的查询语句,得到以下结果(每次执行结果都不太一样) -
sqlSELECT ROUND(RAND() * ( SELECT MAX(id) FROM table)) as id;
我们可以使用上面查询返回的结果集来连接表,如下所示:sqlSELECT t.*FROM table AS t JOIN (SELECT ROUND(RAND() * (SELECT MAX(id) FROM table )) AS id ) AS xWHERE t.id >= x.idLIMIT 1;
使用此技术方法,需要多次执行查询以获取多个随机行,因为如果增加返回行数限制,查询将只提供从随机选择的行开始的顺序行。以下查询是从customer
表中返回一个随机客户。sqlSELECT t.customer_id, t.customer_nameFROM studymysql.customer AS t JOIN (SELECT ROUND(RAND() * (SELECT MAX(customer_id) FROM studymysql.customer)) AS customer_id ) AS xWHERE t.customer_id >= x.customer_idLIMIT 1;
执行上面的查询语句,得到以下结果 - id
列的值落在1...N
的范围内,并且在该范围内的值连续没有间隙,可以使用以下技术:- 首先,在1..N
范围内选择随机数。- 第二步,根据随机数选择行记录。以下语句可帮助您完成此操作:sqlSELECT table. *FROM (SELECT ROUND(RAND() * (SELECT MAX(id) FROM table)) random_num, @num:=@num + 1 FROM (SELECT @num:=0) AS a, table LIMIT N) AS b, table AS tWHERE b.random_num = t.id;
请注意,用户定义的变量是特定于连接的。所以这种技术方法不能用于连接池。此外,主键必须是整数类型,其值必须在值是连续没有间隙的序列中。在本教程中,我们展示了几种从表中选择随机记录的技术方法。StudyMySQL官方QQ群(2): 41840707 欢迎各位MySQL学习和用户加入。