日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

MySQL 生成隨機數(shù)字、字符串、日期、驗證碼及 UUID的方法

瀏覽:74日期:2023-10-06 09:16:21

上一篇介紹了如何在 Oracle 生成隨機數(shù)字、字符串、日期、驗證碼以及 UUID,今天我們繼續(xù)討論在 MySQL 中生成各種隨機數(shù)據(jù)的方法。

📝計算機生成的都是偽隨機數(shù),并不是真正的物理隨機數(shù)。

生成隨機數(shù)字生成 0 到 1 之間的隨機數(shù)

MySQL 中的 RAND 函數(shù)可以用于生成一個大于等于 0 小于 1 的隨機數(shù)字。例如:

SELECT rand();rand() |------------------|0.7245639057127423|SELECT rand();rand() |-------------------|0.01697599982561171|

該函數(shù)返回的數(shù)據(jù)類型為 double,包含 16 位小數(shù);每次調(diào)用都會返回不同的數(shù)據(jù)。

如果想要重現(xiàn)某些場景,需要確保每次運行時生成相同的隨機數(shù)。這種情況下可以為 RAND 函數(shù)傳遞一個輸入?yún)?shù),設(shè)置一個隨機數(shù)種子。例如:

SELECT rand(1);rand(1) |-------------------|0.40540353712197724|SELECT rand(1);rand(1) |-------------------|0.40540353712197724|

從結(jié)果可以看出,相同的種子返回了相同的隨機數(shù)。

生成指定范圍內(nèi)的隨機數(shù)

基于 RAND 函數(shù)和數(shù)學(xué)運算,可以返回任意兩個數(shù)字之間的隨機數(shù):

low + RAND() * (high − low)

以上表達(dá)式將會返回一個大于等于 low,小于 high 的隨機數(shù)。例如:

SELECT 10 + rand(1) * 10;10 + rand(1) * 10 |------------------|14.054035371219772|

以上示例返回了一個大于等于 10 且小于 20 的隨機數(shù)字。

如果想要生成某個范圍內(nèi)的隨機整數(shù),可以加上 FLOOR 函數(shù)。例如:

SELECT floor(10 + rand(1) * (10)) AS rd;rd |----|14.0|

該語句返回了一個大于等于 10,小于等于 19(不是 20)的隨機整數(shù)。

生成 6 位數(shù)字手機驗證碼

我們已經(jīng)獲得了指定范圍內(nèi)的隨機整數(shù),加上 LPAD 函數(shù)就可以生成由 6 位數(shù)字字符組成的手機驗證碼。例如:

SELECT lpad(floor(rand(999) * 1000000), 6, ’0’) AS captcha;captcha|-------|088146 |

其中,lpad 函數(shù)可以確保數(shù)據(jù)不夠 6 位時在前面補足 0。

生成遵循正態(tài)分布的隨機數(shù)

RAND 函數(shù)生成的是一個遵循均勻分布的隨機數(shù),MySQL 沒有提供生成遵循正態(tài)分布(normal distribution)的隨機數(shù)。我們可以創(chuàng)建一個存儲函數(shù)來模擬正態(tài)分布的隨機數(shù):

delimiter //create function normal_distrib(mean double, stdev double) returns double no sqlbeginset @x = rand(), @y = rand();set @nd = (sqrt(-2 * log(@x)) * cos(2 * pi() * @y)) * stdev + mean;return @nd;end//delimiter ;

以上函數(shù)利用 Box-Muller 變換算法通過兩個平均分布的隨機數(shù)生成正態(tài)分布的隨機數(shù)。

以下語句通過 normal_distrib 函數(shù)生成了一個期望值為 0,標(biāo)準(zhǔn)差為 1 的正態(tài)分布隨機數(shù):

SELECT normal_distrib(0,1);normal_distrib(0,1)|-------------------| 1.4930564399841173|

以下語句可以用于驗證 normal_distrib 函數(shù)是否遵循正態(tài)分布:

with recursive temp(val) as ( select normal_distrib(0,1) union all select normal_distrib(0,1) from temp limit 1000000)select /*+ set_var(cte_max_recursion_depth = 1m) */avg(val),std(val)from temp;avg(val) |std(val) |---------------------|------------------|-0.002340136192616743|0.9994844557755181|

通過運行 1000000 次,計算這些數(shù)據(jù)的平均值和標(biāo)準(zhǔn)差,返回結(jié)果非常接近 0 和 1。

生成隨機字符串生成固定長度的隨機字符串

除了隨機數(shù)字之外,有時候我們也需要生成一些隨機的字符串。MySQL 沒有提供專門生成隨機字符串的函數(shù),但是可以通過其他函數(shù)進行模擬。例如:

SELECT char(floor(rand() * 26)+65) as rand_char;rand_char|---------|T |

以上查詢返回了一個隨機的大寫字母,char 函數(shù)用于將 ASCII 碼轉(zhuǎn)換為對應(yīng)的字符。我們可以基于該查詢進一步創(chuàng)建一個存儲函數(shù):

delimiter //create function rand_string(len integer) returns text no sqlbegin declare counter int default 1; declare str text default ’’; if len < 1 then return null; end if; while counter <= len do set str = concat(str, char(floor(rand() * 94) + 33)); set counter = counter + 1; end while; return str;end//delimiter ;

rand_string 函數(shù)可以返回由任意可打印字符(ASCII 碼從 33 到 126)組成的隨機字符串。例如:

rand_string(8)|--------------|7j5dz[58 |

以上示例返回了一個長度為 8,由可打印字符組成的隨機字符串。

另外,MySQL 中的 elt 函數(shù)也可以用于返回指定位置中的元素。例如:

SELECT elt(1 + floor(rand() * 36), 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, ’A’,’B’,’C’,’D’,’E’,’F’,’G’, ’H’,’I’,’J’,’K’,’L’,’M’,’N’, ’O’,’P’,’Q’,’R’,’S’,’T’, ’U’,’V’,’W’,’X’,’Y’,’Z’) as val;val|---|B |

以上語句返回了一個隨機的數(shù)字或者大寫字母,將其替換到 rand_string 函數(shù)可以返回一個由數(shù)字和大寫字母組成的隨機字符串。

生成可變長度的隨機字符串

那么,怎么返回一個長度可變的隨機字符串呢?很簡單,為 rand_string 函數(shù)指定一個隨機的長度參數(shù)即可。例如:

SELECT rand_string(floor(10 + rand() * 11));rand_string(floor(10 + rand() * 11))|------------------------------------|4U13MjO+($}k'cO@5%[ |

以上示例返回了一個長度大于等于 10 且小于等于 20,由可打印字符組成的隨機字符串。

生成隨機日期和時間

將指定日期增加一個隨機的數(shù)字,就可以得到隨機的日期。例如:

SELECT date_add(’2020-01-01’, interval rand() * 31 day) rand_date;rand_date |----------|2020-01-19|

以上示例返回了 2020 年 1 月中的某個隨機日期。以下語句則返回了一天中的某個隨機時間:

SELECT sec_to_time(rand() * 3600) rand_time;rand_time |------------------|00:05:29.546878000|

其中,sec_to_time 函數(shù)用于將秒數(shù)轉(zhuǎn)換為時間數(shù)據(jù)。

獲取表中的隨機記錄

對于返回多行數(shù)據(jù)的查詢語句,RAND 函數(shù)每次都會返回不同的隨機數(shù)據(jù)。例如:

SELECT rand(1) FROM employee;rand(1) |--------------------| 0.40540353712197724| 0.8716141803857071| 0.1418603212962489|...

利用這個特性,我們可以從表中返回隨機的數(shù)據(jù)行。例如:

SELECT emp_id,emp_nameFROM employeeORDER BY rand(1)LIMIT 5;emp_id|emp_name |------|----------| 6|魏延 | 14|張苞 | 16|周倉 | 15|趙統(tǒng) | 1|劉備 |

以上示例從 employee 表中返回了 5 行隨機記錄。該方法需要為表中的每行數(shù)據(jù)都生成一個隨機數(shù),然后進行排序;所以會隨著表中的數(shù)據(jù)量增加而逐漸變慢。

如果表中存在自增主鍵,也可以基于主鍵生成一個隨機數(shù)據(jù)。例如:

SELECT round(rand() * (SELECT max(emp_id) FROM employee)) AS id;id |----|10.0|

然后基于這個隨機數(shù)返回一條隨機的記錄:

SELECT e.emp_id, e.emp_nameFROM employee eINNER JOIN (SELECT round(rand() * (SELECT max(emp_id) FROM employee)) AS id ) AS tWHERE e.emp_id >= t.idLIMIT 1;emp_id|emp_name|------|--------| 9|趙云 |

這種方法一次只能返回一條隨機記錄,而且只有當(dāng)自增字段的值沒有間隙時才會返回均勻分布的隨機記錄。

生成 UUID

UUID(Universal Unique Identifier)或者 GUID(Globally Unique Identifier)是一個 128 比特的數(shù)字,可以用于唯一標(biāo)識每個網(wǎng)絡(luò)對象或資源。由于它的生成機制,一個 UUID 可以保證幾乎不會與其他 UUID 重復(fù),因此常常用于生成數(shù)據(jù)庫中的主鍵值。

MySQL 提供了一個系統(tǒng)函數(shù) UUID,可以用于生成 UUID。例如:

SELECT uuid();uuid()|------------------------------------|35f67fde-e0e9-11ea-9d25-0800272142b1|

如果想要生成沒有中劃線(-)的 UUID,可以使用 REPLACE 函數(shù):

SELECT replace(uuid(),’-’,’’);replace(uuid(),’-’,’’) |--------------------------------|8505290be0ea11ea9d250800272142b1|

除此之外,MySQL 還提供了一個UUID_SHORT 函數(shù),它可以返回一個 64 比特的無符號整數(shù)。例如:

SELECT uuid_short();uuid_short() |-----------------|98862025337208832|

該函數(shù)返回的是一個“短的”唯一標(biāo)識符,只有滿足以下條件時才具有唯一性:

當(dāng)前服務(wù)器的 server_id 位于 0 到 255 之間,并且在復(fù)制結(jié)構(gòu)中具有唯一性; 重啟 mysqld 前后沒有將服務(wù)器主機的系統(tǒng)時間往回調(diào)整; 每秒鐘的平均調(diào)用次數(shù)少于 1600 萬次。總結(jié)

本文介紹了在 MySQL 數(shù)據(jù)庫中生成隨機數(shù)據(jù)的方法,包括隨機數(shù)字、驗證碼、隨機字符串以及隨機日期和時間等,同時還介紹了如何從表中返回隨機記錄,以及如何生成 UUID。

到此這篇關(guān)于MySQL 生成隨機數(shù)字、字符串、日期、驗證碼及 UUID的方法的文章就介紹到這了,更多相關(guān)MySQL 生成隨機數(shù)字 UUID內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: MySQL 數(shù)據(jù)庫
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲精品第一| 一本一本久久| 国产日韩欧美在线播放不卡| 亚洲美洲欧洲综合国产一区| 久久久久久黄| 人人精品亚洲| 亚洲第一精品影视| 99视频精品| 久久久一二三| 国产欧美一区二区三区精品酒店| 久久影院资源站| 黄色精品视频| 国产精品亚洲一区二区在线观看| 国产欧美一区二区色老头| 免费在线成人| 91日韩欧美| 久久精品国产www456c0m| 午夜久久免费观看| 日韩中文字幕区一区有砖一区| 久久最新视频| 欧美一级久久| 国产精品99在线观看| 特黄毛片在线观看| 999久久久免费精品国产| 香蕉成人久久| 亚洲小说春色综合另类电影| 在线一区视频| 日韩高清中文字幕一区| 国产亚洲观看| 97精品中文字幕| 亚洲激情国产| 久久激情五月激情| av免费不卡国产观看| 免费久久精品| 日本aⅴ亚洲精品中文乱码| 国产欧美一区二区三区国产幕精品 | 91成人网在线观看| 免费在线观看不卡| 欧美永久精品| 999久久久免费精品国产| 石原莉奈在线亚洲二区| 国产精品99久久免费| 久久久精品日韩| 亚洲精品婷婷| 日韩成人免费| 亚洲一区av| av资源中文在线| 亚洲精选成人| 高清一区二区三区av| 夜夜嗨av一区二区三区网站四季av| 蜜臀久久99精品久久久久久9| 国产精品久久久久久模特| 久久久人人人| 国产精品多人| 国产精品日韩欧美一区| 麻豆一区二区三| 狠狠爱www人成狠狠爱综合网| 国产欧美日韩影院| 亚洲激精日韩激精欧美精品| 久久精品免视看国产成人| 亚洲电影有码| 日韩精品久久理论片| 日韩在线短视频| 日韩一区二区三区四区五区| 色88888久久久久久影院| 国产精品丝袜xxxxxxx| 国内一区二区三区| 亚洲三级视频| 91精品国产调教在线观看| 国产探花一区二区| 欧美大黑bbbbbbbbb在线| 久久精品国产福利| 日韩精品一区二区三区免费视频 | 美女视频一区在线观看| 天堂а√在线最新版中文在线| 日韩成人在线看| 在线综合欧美| 日本欧美不卡| 欧美91在线|欧美| 99久久www免费| 激情综合五月| 日本国产亚洲| 黄色欧美日韩| 91精品韩国| 老鸭窝一区二区久久精品| 一级成人国产| 欧美女激情福利| 日韩精品诱惑一区?区三区| 欧美有码在线| 亚洲人成毛片在线播放女女| 香蕉久久99| 国产盗摄——sm在线视频| 欧美一区自拍| 婷婷成人av| 免费观看久久av| 久久免费黄色| 婷婷激情一区| 加勒比视频一区| 国产精品1区| 日韩av中文字幕一区二区| 久久高清一区| 国产亚洲一区在线| 欧美日韩国产亚洲一区| 久久国产毛片| 999国产精品| 久久久久免费av| 欧美三区四区| 97精品视频在线看| 黄毛片在线观看| 精品在线网站观看| 欧美激情网址| 免费在线观看一区| 久久天堂影院| 国产不卡一区| 国产精品xx| 黄色在线观看www| 欧美韩日一区| 在线中文字幕播放| 欧美日韩视频网站| 久久影视一区| 黄色亚洲精品| 日韩一区精品字幕| 亚洲精品欧美| 欧美精品福利| 日本伊人久久| 日韩av片子| 美美哒免费高清在线观看视频一区二区 | 综合亚洲自拍| 香蕉精品999视频一区二区| 日韩不卡一区| 亚洲综合日韩| 日韩不卡一二三区| 高清精品久久| 天堂а√在线最新版中文在线| 麻豆久久久久久| 久久精品亚洲一区二区| 国产一区三区在线播放| 久久福利在线| 精品三级av| 亚洲一区资源| 久久精品在线| 国产亚洲精品久久久久婷婷瑜伽| 丝袜脚交一区二区| 日本一区中文字幕| 国产精品99久久免费| 国产精品99一区二区三区| 久久男人天堂| 99久久www免费| 日韩中文字幕麻豆| 国产日产高清欧美一区二区三区 | 国产精品综合色区在线观看| 国产精品第十页| 国产96在线亚洲| 久久精品高清| 亚洲尤物av| 国产精品资源| 日韩免费看片| 六月天综合网| 国产亚洲一区二区三区不卡| 国产精品麻豆成人av电影艾秋 | 欧美另类专区| 日韩精品第一| 亚洲精品成a人ⅴ香蕉片| 美腿丝袜亚洲三区| 亚洲福利国产| 日韩不卡一区二区| 日本蜜桃在线观看视频| 婷婷色综合网| 国产欧美欧美| 九色精品91| 国产视频一区二| 久久久久.com| 蜜臀久久久99精品久久久久久| 久久国产视频网| 亚洲四虎影院| 少妇精品在线| 91亚洲成人| 亚洲免费资源| av中文字幕在线观看第一页| 亚洲一区日本| 国产一区二区三区四区| 欧美日韩国产探花| 免费看久久久| 亚洲一区二区三区高清不卡| 久久伊人久久| 老牛国产精品一区的观看方式| 国产精品a级| 亚洲精品网址| 久久精品国产99国产| 9色精品在线| 国产激情在线播放| 日本一区福利在线| 在线成人动漫av| 国产精品videossex久久发布| 欧美另类综合| 国产一区二区色噜噜| 亚洲综合激情在线| 久久中文字幕av| 国产中文欧美日韩在线| 亚洲精品乱码久久久久久蜜桃麻豆 |