用MySQL里的Rand()生成不连续重复的随机数年龄以及随机姓名字符串_MySQL
前言:
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 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 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)
四,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>

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











PHP에서 int 유형을 문자열로 변환하는 방법에 대한 자세한 설명 PHP 개발에서 int 유형을 문자열 유형으로 변환해야 하는 경우가 종종 있습니다. 이 변환은 다양한 방법으로 수행할 수 있습니다. 이 기사에서는 독자의 이해를 돕기 위해 특정 코드 예제와 함께 몇 가지 일반적인 방법을 자세히 소개합니다. 1. PHP 내장 함수 strval()을 사용하세요. PHP는 다양한 유형의 변수를 문자열 유형으로 변환할 수 있는 내장 함수 strval()을 제공합니다. int형을 string형으로 변환해야 할 때,

Golang에서 문자열이 특정 문자로 시작하는지 확인하는 방법은 무엇입니까? Golang으로 프로그래밍할 때 문자열이 특정 문자로 시작하는지 확인해야 하는 상황에 자주 직면하게 됩니다. 이 요구 사항을 충족하기 위해 Golang의 문자열 패키지에서 제공하는 기능을 사용할 수 있습니다. 다음에는 Golang을 사용하여 문자열이 특정 문자로 시작하는지 확인하는 방법을 구체적인 코드 예제와 함께 자세히 소개하겠습니다. Golang에서는 strings 패키지의 HasPrefix를 사용할 수 있습니다.

제목: Golang에서 문자열이 특정 문자로 끝나는지 확인하는 방법 Go 언어에서는 문자열을 처리할 때 문자열이 특정 문자로 끝나는지 확인해야 하는 경우가 있습니다. 이 기사에서는 Go 언어를 사용하여 이 기능을 구현하는 방법을 소개하고 참조용 코드 예제를 제공합니다. 먼저 Golang에서 문자열이 지정된 문자로 끝나는지 확인하는 방법을 살펴보겠습니다. Golang의 문자열에 포함된 문자는 인덱싱을 통해 얻을 수 있으며, 문자열의 길이는 다음과 같습니다.

1. 먼저 pycharm을 열고 pycharm 홈페이지로 들어갑니다. 2. 그런 다음 새 Python 스크립트를 생성하고 마우스 오른쪽 버튼을 클릭하고 새로 만들기를 클릭한 후 Pythonfile을 클릭합니다. 3. 문자열(코드: s="-")을 입력합니다. 4. 그런 다음 문자열의 기호를 20번 반복해야 합니다(코드: s1=s*20). 5. 인쇄 출력 코드(코드: print(s1))를 입력합니다. 6. 마지막으로 스크립트를 실행하면 하단에 반환 값이 표시됩니다. - 20번 반복됩니다.

PHP에서 16진수 문자열을 변환할 때 중국어 문자가 깨지는 문제를 해결하는 방법 PHP 프로그래밍에서 때때로 16진수 문자열을 일반 중국어 문자로 변환해야 하는 상황에 직면합니다. 그러나 이러한 변환 과정에서 때때로 중국어 문자가 깨져 나오는 문제에 직면하게 됩니다. 이 기사에서는 PHP에서 16진수를 문자열로 변환할 때 중국어 문자가 깨지는 문제를 해결하는 방법과 구체적인 코드 예제를 제공합니다. 16진수 변환을 위해서는 hex2bin() 함수를 사용하세요. PHP에 내장된 hex2bin() 함수는 1을 변환할 수 있습니다.

PHP 문자열 일치 팁: 모호한 포함 표현식 방지 PHP 개발에서 문자열 일치는 일반적으로 특정 텍스트 내용을 찾거나 입력 형식을 확인하는 데 사용되는 일반적인 작업입니다. 그러나 일치 정확도를 보장하기 위해 모호한 포함 표현식을 사용하지 말아야 할 경우도 있습니다. 이 기사에서는 PHP에서 문자열 일치를 수행할 때 모호한 포함 표현식을 방지하는 몇 가지 기술을 소개하고 구체적인 코드 예제를 제공합니다. 정확한 일치를 위해 preg_match() 함수를 사용하십시오. PHP에서는 preg_mat를 사용할 수 있습니다.

PHP 문자열 작업: 공백을 효과적으로 제거하는 실용적인 방법 PHP 개발 시 문자열에서 공백을 제거해야 하는 상황에 자주 직면하게 됩니다. 공백을 제거하면 문자열이 더 깔끔해지고 후속 데이터 처리 및 표시가 쉬워집니다. 이 기사에서는 공백을 제거하는 몇 가지 효과적이고 실용적인 방법을 소개하고 구체적인 코드 예제를 첨부합니다. 방법 1: PHP 내장 함수인 Trim()을 사용합니다. PHP 내장 함수인 Trim()을 사용하면 문자열 양쪽 끝의 공백(공백, 탭, 개행 등 포함)을 제거할 수 있어 매우 편리하고 쉽습니다. 사용.

웹 애플리케이션 개발에 널리 사용되는 스크립팅 언어로서 PHP는 매우 강력한 문자열 처리 기능을 가지고 있습니다. 일상적인 개발 과정에서 문자열, 특히 문자열의 마지막 두 문자를 삭제해야 하는 작업을 자주 접하게 됩니다. 이 기사에서는 문자열의 마지막 두 문자를 삭제하는 두 가지 PHP 기술을 소개하고 구체적인 코드 예제를 제공합니다. 팁 1: substr 함수 사용 PHP의 substr 함수는 문자열의 일부를 반환하는 데 사용됩니다. 문자열과 시작 위치를 지정하여 쉽게 문자를 제거할 수 있습니다.
