在 MySQL 中獲取隨機值

Preet Sanghavi 2023年1月30日
  1. 使用 INSERT 語句在 student_dates 表中插入條目
  2. 使用 ORDER BY 語句隨機獲取 student_dates 表的值
在 MySQL 中獲取隨機值

本教程旨在瞭解如何在 MySQL 中對錶的值或記錄進行隨機排序或排序。

大多數使用 MySQL 進行資料分析或視覺化的企業和組織都需要根據不同的標準對其使用者的不同表值進行排序。

測試是否正確檢查了 MySQL 表中的不同使用者的最有效技術之一是隨機訪問使用者。它可以幫助避免衝突並基於特定平臺更好地瞭解使用者。

MySQL 使用 RAND() 函式幫助分析人員訪問隨機記錄。此外,我們需要使用 LIMIT 關鍵字來使用 RAND() 語句快速獲取資料。

例如,如果分析人員需要從超過 100,000 條記錄的表中快速獲取 10 條記錄,他們可以使用帶有 LIMIT 關鍵字的 RAND() 函式。讓我們嘗試更深入地理解這句話。

但是,在開始之前,我們建立一個虛擬資料集來使用。在這裡,我們建立了一個表 student_dates 以及幾行。

-- create the table student_dates
CREATE TABLE student_dates(
  stu_id int,
  stu_firstName varchar(255) DEFAULT NULL,
  stu_date date,
  primary key(stu_id)
);

使用 INSERT 語句在 student_dates 表中插入條目

前面的查詢建立了一個名為 student_dates 的表。現在在 INSERT 語句的幫助下,讓我們嘗試為一些學生新增資料。此操作可按如下方式進行:

-- insert rows to the table student_dates
INSERT INTO student_dates(stu_id,stu_firstName,stu_date) 
 VALUES(1,"Preet",STR_TO_DATE('24-May-2005', '%d-%M-%Y')),
 (2,"Dhruv",STR_TO_DATE('14-June-2001', '%d-%M-%Y')),
 (3,"Mathew",STR_TO_DATE('13-December-2020', '%d-%M-%Y')),
 (4,"Jeet",STR_TO_DATE('14-May-2003', '%d-%M-%Y')),
 (5,"Steyn",STR_TO_DATE('19-July-2002', '%d-%M-%Y'));

上面的程式碼將在表 student_dates 中輸入學生資料。我們可以使用以下命令視覺化該表。

SELECT * from student_dates;

輸出:

stu_id	stu_firstName	stu_date
1		Preet			2005-05-24
2		Dhruv			2001-06-14
3		Mathew			2020-12-13
4		Jeet			2003-05-14
5		Steyn			2002-07-19

使用 ORDER BY 語句隨機獲取 student_dates 表的值

如上所述,我們可以使用 MySQL 中的 sort by 語句對值進行排序。此邏輯還可用於對錶中的記錄進行隨機排序。

語法:

SELECT * from name_of_the_table
ORDER BY RAND();

正如我們在上面看到的,所有的表記錄都將使用 RAND() 函式隨機排序。我們可以將這個概念應用到我們的 student_dates 表中。可以使用以下查詢執行此操作。

SELECT * from student_dates
ORDER BY RAND();

輸出:

stu_id	stu_firstName	stu_date
5		Steyn			2002-07-19
3		Mathew			2020-12-13
4		Jeet			2003-05-14
1		Preet			2005-05-24
2		Dhruv			2001-06-14

正如我們在上述程式碼塊中看到的,所有 student_dates 表記錄都是隨機排序的。

輸出:

stu_id	stu_firstName	stu_date
4		Jeet			2003-05-14
1		Preet			2005-05-24
2		Dhruv			2001-06-14
3		Mathew			2020-12-13
5		Steyn			2002-07-19

正如我們從上面塊的輸出中看到的,這些值是隨機排序的。

現在,要使用設定為 random 函式的特定上限快速獲取詳細資訊,我們可以使用上面建議的 LIMIT 關鍵字。可以使用以下語法執行此操作。

SELECT * from student_dates
ORDER BY RAND()
LIMIT 3;

如上面的查詢所示,我們的目標是從我們的 student_dates 表中僅獲取三個隨機獲取的記錄。

輸出:

stu_id	stu_firstName	stu_date
2		Dhruv			2001-06-14
1		Preet			2005-05-24
3		Mathew			2020-12-13

因此,藉助 ORDER BY 語句和 RAND() 函式以及 LIMIT 關鍵字,我們可以有效地對 MySQL 中特定表的不同記錄進行隨機快速的排序。

作者: Preet Sanghavi
Preet Sanghavi avatar Preet Sanghavi avatar

Preet writes his thoughts about programming in a simplified manner to help others learn better. With thorough research, his articles offer descriptive and easy to understand solutions.

LinkedIn GitHub