亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL rand()函數(shù)、rand(n)、生成不重復隨機數(shù)

 更新時間:2024年11月18日 10:48:56   作者:五月天的尾巴  
MySQL提供了rand()函數(shù)來生成隨機數(shù),包括無參數(shù)rand()和有參數(shù)rand(n)等,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

有時候我們想要生成一個唯一不重復的隨機數(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)方法

    這篇文章主要介紹了關于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語句的使用

    MySQL中ON DUPLICATE KEY UPDATE語句的使用

    INSERT INTO ... ON DUPLICATE KEY UPDATE?是一個強大的SQL語句,它結合了插入新記錄和更新已存在記錄的功能于一體,本文就來介紹一下MySQL中ON DUPLICATE KEY UPDATE語句的使用,感興趣的可以了解一下
    2024-08-08
  • MySQL無法創(chuàng)建外鍵的原因及解決方法

    MySQL無法創(chuàng)建外鍵的原因及解決方法

    這篇文章主要介紹了MySQL無法創(chuàng)建外鍵的原因及解決方法,然后在文中給大家及時了MySQL無法創(chuàng)建外鍵、查詢外鍵的屬性知識,感興趣的朋友一起看看吧
    2017-10-10
  • MySQL數(shù)據(jù)庫如何正確設置主鍵

    MySQL數(shù)據(jù)庫如何正確設置主鍵

    主鍵是用于唯一標識數(shù)據(jù)庫表中每一行數(shù)據(jù)的一列或一組列,主鍵可以確保數(shù)據(jù)的唯一性和完整性,這篇文章主要給大家介紹了關于MySQL數(shù)據(jù)庫如何正確設置主鍵的相關資料,需要的朋友可以參考下
    2024-04-04
  • MySQL錯誤ERROR 2002 (HY000): Can''t connect to local MySQL server through socket

    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
  • MySql5.7.18字符集配置圖文詳解

    MySql5.7.18字符集配置圖文詳解

    本文通過圖文并茂的形式給大家介紹了mysql5.7.18字符集配置教程,非常不錯,具有參考借鑒價值,需要的朋友參考下吧
    2017-06-06
  • win2008 R2 WEB環(huán)境配置之MYSQL 5.6.22安裝版安裝配置方法

    win2008 R2 WEB環(huán)境配置之MYSQL 5.6.22安裝版安裝配置方法

    這篇文章主要介紹了win2008 R2 WEB環(huán)境配置之MYSQL 5.6.22安裝版安裝配置方法,需要的朋友可以參考下
    2016-06-06
  • Mysql的row_number函數(shù)使用介紹

    Mysql的row_number函數(shù)使用介紹

    這篇文章主要為大家介紹了Mysql的row_number函數(shù)使用原理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-09-09
  • 淺析MySQL并行復制

    淺析MySQL并行復制

    這篇文章主要介紹了MySQL并行復制的相關資料,幫助大家更好的理解和使用MySQL數(shù)據(jù)庫,感興趣的朋友可以了解下
    2020-11-11
  • 一篇文章看懂SQL中的開窗函數(shù)

    一篇文章看懂SQL中的開窗函數(shù)

    開窗函數(shù)也叫分析函數(shù)有兩類,一類是聚合開窗函數(shù),一類是排序開窗函數(shù),下面這篇文章主要給大家介紹了關于SQL中開窗函數(shù)的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-08-08

最新評論