MYSQL生成隨機數的幾種方式

1.uuid()生成隨機數--32位
select replace(uuid(),"-","") as uuid;

2.uuid_short()生成隨機數--17--20位不等隨機

select replace(uuid_short(),"-","") as uuid;

3.floor()生成隨機數--需要幾位自由定義(例子是生成18位的)

規則:生成≥a且≤b的隨機數
x=a
y=(b-a)+1

select floor(x+rand()*y);

例如-18位數字:select floor(100000000000000000+rand()*900000000000000001);

4.rand()生成隨機數--需要幾位自由定義(例子是生成5位的)

-- 生成 5 位的隨機數
SELECT CEILING(RAND()*90000+10000) id;

對第四種多加幾嘴:

CEILING    向上取整

FLOOR    向下取整

-- 生成 0~1 之間的隨機小數
0 < RAND() <1
 
-- 乘以 9000,變成 0~9000 之間隨機小數
0 < RAND*9000 < 9000
 
-- 加上 1000,變成 0~10000 之間的隨機小數
0 < RAND*9000+1000 < 10000
 
-- 使用 CEILING 函數向上取整,去掉後面的小數,得到一個整數
-- 或使用 FLOOR 函數向下取整,都可以
CEILING(RAND()*9000+1000)
-- 或
FLOOR(RAND()*9000+1000)

發佈了39 篇原創文章 · 獲贊 8 · 訪問量 3萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章