MySQL rand()函數(shù)、rand(n)、生成不重復隨機數(shù)
有時候我們想要生成一個唯一不重復的隨機數(shù),mysql提供了rand()函數(shù)來實現(xiàn)該功能。
本文首先介紹rand()的基本使用,分別介紹round與rand的合用、ceiling與rand的合用、floor與rand的合用、md5與rand的合用
一、rand()與rand(n)
- rand() 即無參數(shù)的,會生成一個[0,1)之間的float型隨機數(shù)。此時產(chǎn)生的隨機數(shù)是
隨機的,不可重復的; - rand(n),即有參數(shù)數(shù),它會使用參數(shù)n作為隨機數(shù)生成的種子。每次使用相同的種子值n,將得到相同的隨機排序結果。因此
這種隨機數(shù)是可重復的。這種隨機數(shù)也是偽隨機的
rand(n)函數(shù):
- n是int類型的數(shù)字,所以只要是數(shù)字就行。不同的種子值生成的隨機數(shù)是不一樣的;對于同一個種子值n,每次返回的隨機數(shù)是固定的。
- 同一次查詢時,結果集中可能會產(chǎn)生重復隨機數(shù)。
- 多次查詢時,每次返回的隨機數(shù)與上一次是一致的。
注意:頻繁地在一個很大的數(shù)據(jù)集上使用RAND()可能會導致性能問題,因為這會導致數(shù)據(jù)庫引擎在每次查詢時都生成一個新的隨機數(shù)。
示例如下:
mysql> select rand(),rand(),rand(); +--------------------+--------------------+-------------------+ | rand() | rand() | rand() | +--------------------+--------------------+-------------------+ | 0.9601070507989331 | 0.7956807881553478 | 0.098082819113585 | +--------------------+--------------------+-------------------+ 1 row in set (0.00 sec) mysql> select rand(1),rand(1),rand(1); +---------------------+---------------------+---------------------+ | rand(1) | rand(1) | rand(1) | +---------------------+---------------------+---------------------+ | 0.40540353712197724 | 0.40540353712197724 | 0.40540353712197724 | +---------------------+---------------------+---------------------+ 1 row in set (0.00 sec)
我們發(fā)現(xiàn):
- 當直接調用rand()函數(shù)時,每次生成的隨機數(shù)都是不同的。
- 當直接調用rand(n)函數(shù)時,若種子n相同,則生成的隨機數(shù)是可重復且多次查詢是一致的。
上面我們說rand(n)函數(shù),每次使用相同的種子值n,將得到相同的隨機排序結果,這是什么意思呢?為了便于理解上面兩種示例,我們把rand(),rand(n) 結合表數(shù)據(jù)一起看一下。
mysql> CREATE TABLE t (i INT); Query OK, 0 rows affected (0.42 sec) mysql> INSERT INTO t VALUES(1),(2),(3); Query OK, 3 rows affected (0.00 sec) Records: 3 Duplicates: 0 Warnings: 0 -- 如下:rand()函數(shù)查詢了兩次,每次查詢每一行返回的隨機數(shù)都不相同 mysql> SELECT i, RAND() FROM t; +------+------------------+ | i | RAND() | +------+------------------+ | 1 | 0.61914388706828 | | 2 | 0.93845168309142 | | 3 | 0.83482678498591 | +------+------------------+ 3 rows in set (0.00 sec) mysql> SELECT i, RAND() FROM t; +------+------------------+ | i | RAND() | +------+------------------+ | 1 | 0.35877890638893 | | 2 | 0.28941420772058 | | 3 | 0.37073435016976 | +------+------------------+ 3 rows in set (0.00 sec) -- 如下:rand(n)函數(shù)查詢了兩次 -- 同一次查詢中可能會返回重復的數(shù)字(注意:數(shù)據(jù)量小的情況不一定有重復值) -- 但是多次查詢時,第二次與第一次返回的結果相同。 mysql> SELECT i, RAND(3) FROM t; +------+------------------+ | i | RAND(3) | +------+------------------+ | 1 | 0.90576975597606 | | 2 | 0.37307905813035 | | 3 | 0.90576975597606 | +------+------------------+ 3 rows in set (0.00 sec) mysql> SELECT i, RAND(3) FROM t; +------+------------------+ | i | RAND(3) | +------+------------------+ | 1 | 0.90576975597606 | | 2 | 0.37307905813035 | | 3 | 0.90576975597606 | +------+------------------+ 3 rows in set (0.01 sec)
可以發(fā)現(xiàn):
- rand()函數(shù):每次查詢都生成不一樣的數(shù)據(jù)。同一次查詢中每行數(shù)據(jù)的隨機數(shù)都不一樣;
多次查詢時與上一次生成的隨機數(shù)也不一致。 - rand(n)函數(shù):
同一次查詢中數(shù)據(jù)可能會產(chǎn)生重復(注意:數(shù)據(jù)量小的情況不一定有重復值);多次查詢時與上一次生成的隨機數(shù)是一致的。即是指定了隨機數(shù)的種子,那么多次查詢的結果是一樣的。
二、rand()使用示例
2.1、rand()與order by/group by使用隨機排序分組
rand()函數(shù)用于隨機生成一個不重復的數(shù)字,所以當rand()與order by組合使用時,可以實現(xiàn)數(shù)據(jù)隨機排序。
使用場景: 例如可以用于樣本抽樣,先對數(shù)據(jù)進行隨機排序,然后抽取前x條。
注意:因為是隨機排序,所以每次返回不同的結果。如果目標是以隨機順序檢索行,則可以使用這樣的語句。
SELECT * FROM tbl_name ORDER BY RAND();
2.2、round()與rand()的組合使用
round(n,m):對處理的數(shù)據(jù)進行四舍五入,
n:處理的數(shù)據(jù)
m:保留的小數(shù)位數(shù)
實例1.獲取某個區(qū)間的數(shù)據(jù)
-- 獲取0-100之間的整數(shù) select round(100*rand(),0):

實例2:獲取[40,60)的兩位小數(shù)
select 40+round(20*rand(),2) ps:20為60-40的差值

2.3、rand與ceiling的組合使用
ceiling(n):對于數(shù)據(jù)n向上取整
實例1:select ceiling(1.12)

實例2:select ceiling(rand());rand():隨機在[0,1)之間,故結果肯定為1

實例3:隨機獲取[60,80)之間的整數(shù)
select ceiling(60+rand()*20);

2.4、rand與floor組合使用
floor():是向下取整
實例1:select floor(53.68)

實例2:select floor(rand());ps:rand()向下取整必然為0

實例3:[40,52)之間取整
select floor(40+rand()*12);

2.5、rand與md5組合使用
md5(n):必須要有參數(shù)n,計算n對應的md5摘要,并返回32位的十六進制的字符串
ps:如果n為 NULL,MySQL MD5() 函數(shù)返回 NULL
實例1:select md5(123.44);

實例2:select md5(rand());

三、總結
3.1、rand()與rand(n)的區(qū)別
rand()函數(shù)
- 每次生成是隨機數(shù)都是
不一致且不重復的。 - 適用場景:樣本抽樣,對數(shù)據(jù)隨機排序后獲取前x條。每次排序的結果都是隨機的、不一致的。
rand(n:int)函數(shù)
- n是個int類型的種子參數(shù),每個種子生成的隨機數(shù)都是不同的。但是相同的種子每次返回的隨機數(shù)都是固定的。如rand(2)每次返回的值是固定的。
- 同一次查詢時結果集中可能會產(chǎn)生重復的數(shù)字。
- 多次查詢時每次返回的隨機數(shù)與上一次查詢結果一致。
- 適用場景:用于需要重復生成相同隨機數(shù)序列的場景,例如模擬實驗或測試中需要重復執(zhí)行相同的隨機操作。
到此這篇關于MySQL rand()函數(shù)、rand(n)、生成不重復隨機數(shù)的文章就介紹到這了,更多相關MySQL rand() rand(n)內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
關于MySql數(shù)據(jù)庫Update批量更新不同值的實現(xiàn)方法
這篇文章主要介紹了關于MySql數(shù)據(jù)庫Update批量更新不同值的實現(xiàn)方法,數(shù)據(jù)庫管理系統(tǒng)可以通過SQL管理數(shù)據(jù)庫,定義和操作數(shù)據(jù),維護數(shù)據(jù)的完整性和安全性,需要的朋友可以參考下2023-05-05
MySQL中ON DUPLICATE KEY UPDATE語句的使用
INSERT INTO ... ON DUPLICATE KEY UPDATE?是一個強大的SQL語句,它結合了插入新記錄和更新已存在記錄的功能于一體,本文就來介紹一下MySQL中ON DUPLICATE KEY UPDATE語句的使用,感興趣的可以了解一下2024-08-08
MySQL錯誤ERROR 2002 (HY000): Can''t connect to local MySQL ser
這篇文章主要介紹了MySQL錯誤ERROR 2002 (HY000): Can't connect to local MySQL server through socket,需要的朋友可以參考下2014-10-10
win2008 R2 WEB環(huán)境配置之MYSQL 5.6.22安裝版安裝配置方法
這篇文章主要介紹了win2008 R2 WEB環(huán)境配置之MYSQL 5.6.22安裝版安裝配置方法,需要的朋友可以參考下2016-06-06

