用MySQL裡的Rand()生成不連續重復的隨機數年齡以及隨機姓名字符串
前言:
RAND函數,返回在范圍0到1.0內的隨機浮點值。如果一個整數參數N被指定,它被用作種子值。
一,朋友問題描述如下:
通過一段存儲過程來實現向表裡插入100數據,其中年齡隨機
(2),然後我寫出的代碼如下:
-- 創建用戶表,在project裡
(3),執行結果
call pro3(100); -- 執行過程
二,分析原因
所以存儲過程改動如下:
DELIMITER $$
USE `test`$$
DROP PROCEDURE IF EXISTS `pro3`$$
CREATE PROCEDURE `pro3`(num INT)
BEGIN
DECLARE fname CHAR(1);
DECLARE name1 CHAR(1);
DECLARE name2 CHAR(1);
DECLARE fullname VARCHAR(3);
DECLARE pre_fullname VARCHAR(3) DEFAULT \'\';
DECLARE age INT;
DECLARE i INT DEFAULT 1;
WHILE i <=num DO
SET fname = SUBSTRING(\'趙錢孫李周吳鄭王\',FLOOR(1+8*RAND()),1);
SET name1 = SUBSTRING(\'一二三四五六七八九十甲乙丙丁\',ROUND(1+14*RAND()),1);
SET name2 = SUBSTRING(\'一二三四五六七八九十甲乙丙丁\',ROUND(1+14*RAND()),1);
IF ROUND(RAND())=0 THEN
SET fullname = CONCAT(fname,name1);
END IF;
IF ROUND(RAND())=1 THEN
SET fullname = CONCAT(fname,name1,name2);
END IF;
SET age = FLOOR(20+31*RAND());
/* 給臨時變量賦值,看最新的一條記錄的name值 */
SELECT NAME INTO pre_fullname FROM user1 ORDER BY id DESC LIMIT 1;
/* 開始判斷,如果剛賦值的name跟上一次賦值的name值一樣,就跳過,i保持不變,繼續取值;否則i+1,繼續循環取值*/
IF fullname=pre_fullname AND i>1 THEN
SET i=i;
ELSEIF fullname IS NULL THEN
SET i=i;
ELSE
INSERT INTO user1 VALUES(NULL,fullname,age);
SET i = i + 1;
END IF ;
END WHILE;
END$$
DELIMITER
三,執行改動後的存儲過程,查看效果
mysql> DELIMITER $$
mysql> USE `test`$$
Database changed
mysql> DROP PROCEDURE IF EXISTS `pro3`$$
Query OK, 0 rows affected, 1 warning (0.00 sec)
mysql> CREATE PROCEDURE `pro3`(num INT)
-> BEGIN
-> DECLARE fname CHAR(1);
-> DECLARE name1 CHAR(1);
-> DECLARE name2 CHAR(1);
-> DECLARE fullname VARCHAR(3);
-> DECLARE pre_fullname VARCHAR(3) DEFAULT \'\';
-> DECLARE age INT;
-> DECLARE i INT DEFAULT 1;
-> WHILE i <=num DO
-> SET fname = SUBSTRING(\'趙錢孫李周吳鄭王\',FLOOR(1+8*RAND()),1);
-> SET name1 = SUBSTRING(\'一二三四五六七八九十甲乙丙丁\',ROUND(1+14*RAND()),1);
-> SET name2 = SUBSTRING(\'一二三四五六七八九十甲乙丙丁\',ROUND(1+14*RAND()),1);
->
-> IF ROUND(RAND())=0 THEN
-> SET fullname = CONCAT(fname,name1);
-> END IF;
-> IF ROUND(RAND())=1 THEN
-> SET fullname = CONCAT(fname,name1,name2);
-> END IF;
->
-> SET age = FLOOR(20+31*RAND());
-> /* 給臨時變量賦值,看最新的一條記錄的name值 */
-> SELECT NAME INTO pre_fullname FROM user1 ORDER BY id DESC LIMIT 1;
-> /* 開始判斷,如果剛賦值的name跟上一次賦值的name值一樣,就跳過,i保持不變,繼續取值;否則i+1,繼續循環取值*/
-> IF fullname=pre_fullname AND i>1 THEN
->
Display all 799 possibilities? (y or n)
-> SET i=i;
-> ELSEIF fullname IS NULL THEN
->
Display all 799 possibilities? (y or n)
-> SET i=i;
Display all 799 possibilities? (y or n)
-> SET i=i;
-> ELSE
->
Display all 799 possibilities? (y or n)
-> INSERT INTO user1 VALUES(NULL,fullname,age);
->
Display all 799 possibilities? (y or n)
-> SET i = i + 1;
-> END IF ;
-> END WHILE;
-> END$$
Query OK, 0 rows affected (0.00 sec)
mysql> DELIMITER ;
mysql>
mysql> truncate table user1;
Query OK, 0 rows affected (0.01 sec)
mysql> select * from user1;
Empty set (0.00 sec)
mysql> call pro3(100);
Query OK, 1 row affected (0.11 sec)
mysql> select * from user1;
+-----+-----------+-----+
| id | name | age |
+-----+-----------+-----+
| 1 | 吳甲九 | 32 |
| 2 | 趙丙 | 49 |
| 3 | 錢二 | 40 |
| 4 | 鄭二丙 | 34 |
| 5 | 孫四三 | 39 |
| 6 | 錢五十 | 39 |
| 7 | 趙五 | 23 |
| 8 | 鄭九 | 22 |
| 9 | 錢九七 | 47 |
| 10 | 鄭七乙 | 39 |
| 11 | 孫丙二 | 44 |
| 12 | 吳三九 | 30 |
| 13 | 錢九四 | 28 |
| 14 | 王十九 | 49 |
| 15 | 周丙乙 | 43 |
| 16 | 王十 | 33 |
| 17 | 錢乙七 | 36 |
| 18 | 趙七四 | 32 |
| 19 | 鄭八二 | 31 |
| 20 | 趙二 | 35 |
| 21 | 趙丙 | 26 |
| 22 | 鄭甲丁 | 38 |
| 23 | 周丙九 | 50 |
| 24 | 李丙五 | 27 |
| 25 | 李五三 | 37 |
| 26 | 孫丙六 | 46 |
| 27 | 錢八 | 37 |
| 28 | 周七六 | 40 |
| 29 | 李一一 | 45 |
| 30 | 錢十七 | 22 |
| 31 | 吳七一 | 49 |
| 32 | 吳丙六 | 39 |
| 33 | 吳四四 | 50 |
| 34 | 鄭八丙 | 28 |
| 35 | 吳五七 | 26 |
| 36 | 吳甲 | 46 |
| 37 | 錢四 | 39 |
| 38 | 王丙九 | 24 |
| 39 | 王八八 | 38 |
| 40 | 吳乙丙 | 35 |
| 41 | 吳丙七 | 39 |
| 42 | 周甲丁 | 31 |
| 43 | 錢二甲 | 25 |
| 44 | 錢五丁 | 32 |
| 45 | 孫四二 | 28 |
| 46 | 李七丙 | 37 |
| 47 | 錢七七 | 46 |
| 48 | 鄭乙四 | 33 |
| 49 | 錢甲丁 | 34 |
| 50 | 王五 | 37 |
| 51 | 吳一 | 44 |
| 52 | 王二十 | 33 |
| 53 | 鄭四 | 41 |
| 54 | 錢九八 | 29 |
| 55 | 李十十 | 24 |
| 56 | 錢六七 | 44 |
| 57 | 王二 | 38 |
| 58 | 周五 | 36 |
| 59 | 吳九 | 44 |
| 60 | 趙丙 | 38 |
| 61 | 李五五 | 20 |
| 62 | 王八乙 | 33 |
| 63 | 王丙八 | 49 |
| 64 | 王九六 | 38 |
| 65 | 錢七 | 45 |
| 66 | 趙二二 | 36 |
| 67 | 錢五乙 | 40 |
| 68 | 孫甲七 | 43 |
| 69 | 鄭甲五 | 47 |
| 70 | 趙丙 | 20 |
| 71 | 鄭四 | 43 |
| 72 | 孫丙五 | 24 |
| 73 | 孫三 | 33 |
| 74 | 趙四乙 | 31 |
| 75 | 李 | 44 |
| 76 | 吳九丁 | 43 |
| 77 | 鄭甲一 | 33 |
| 78 | 李三五 | 37 |
| 79 | 王二 | 31 |
| 80 | 趙七丙 | 35 |
| 81 | 吳三十 | 22 |
| 82 | 李二 | 50 |
| 83 | 李八 | 49 |
| 84 | 王一 | 27 |
| 85 | 王三 | 22 |
| 86 | 周五 | 45 |
| 87 | 鄭八 | 44 |
| 88 | 鄭甲二 | 48 |
| 89 | 趙乙 | 37 |
| 90 | 周四五 | 30 |
| 91 | 周二七 | 41 |
| 92 | 孫四 | 21 |
| 93 | 周丙七 | 24 |
| 94 | 孫丁乙 | 32 |
| 95 | 周九一 | 20 |
| 96 | 周九 | 32 |
| 97 | 趙二一 | 26 |
| 98 | 周丁五 | 47 |
| 99 | 孫三 | 38 |
| 100 | 吳十四 | 29 |
+-----+-----------+-----+
100 rows in set (0.00 sec)
mysql>從中看到已經連續100個隨機數中,沒有出現連續重復的姓名和年齡。
四,RAND()與RAND(N)區別
每個種子產生的隨機數序列是不同的,如果傳入N參數執行RAND(N),則每次查詢到的隨機數都是固定的,如果沒有傳入N參數,則每次都是隨機的值。如下所示:
mysql> SELECTRAND(),RAND(5);
+--------------------+---------------------+
| RAND() | RAND(5) |
+--------------------+---------------------+
| 0.7946587333405938 | 0.40613597483014313 |
+--------------------+---------------------+
1 row in set (0.00 sec)
mysql> SELECT RAND(),RAND(5);
+---------------------+---------------------+
| RAND() | RAND(5) |
+---------------------+---------------------+
| 0.12910866749389904 | 0.40613597483014313 |
+---------------------+---------------------+
1 row in set (0.00 sec)
mysql> SELECT RAND(),RAND(5);
+-------------------+---------------------+
| RAND() | RAND(5) |
+-------------------+---------------------+
| 0.261567168181359 | 0.40613597483014313 |
+-------------------+---------------------+
1 row in set (0.00 sec)
mysql> SELECT RAND(),RAND(5);
+--------------------+---------------------+
| RAND() | RAND(5) |
+--------------------+---------------------+
| 0.9205098691587428 | 0.40613597483014313 |
+--------------------+---------------------+
1 row in set (0.00 sec)
mysql> SELECT RAND(),RAND(5);
+--------------------+---------------------+
| RAND() | RAND(5) |
+--------------------+---------------------+
| 0.8178478719832821 | 0.40613597483014313 |
+--------------------+---------------------+
1 row in set (0.00 sec)
mysql>