今天博主在坛子里头看到一位朋友的提问,要求是插入随机字符串。具体描述如下:
在MYSQL中,列出前6位固定为123456的16位随机字符串。随机字符串包括字母a-z、A-Z、0-9。
方法很多,博主在这里和大家分享下:
一:select concat(‘123456′,left(replace(uuid(),’-‘,”),10)) as rand_str;”
二:SELECT CONCAT(‘123456’,
CASE ROUND((RAND())*2) WHEN 0 THEN ROUND((RAND())*9) WHEN 1 THEN CHAR(ROUND((RAND())*25)+97) ELSE CHAR(ROUND((RAND())*25)+65) END,
CASE ROUND((RAND())*2) WHEN 0 THEN ROUND((RAND())*9) WHEN 1 THEN CHAR(ROUND((RAND())*25)+97) ELSE CHAR(ROUND((RAND())*25)+65) END,
CASE ROUND((RAND())*2) WHEN 0 THEN ROUND((RAND())*9) WHEN 1 THEN CHAR(ROUND((RAND())*25)+97) ELSE CHAR(ROUND((RAND())*25)+65) END,
CASE ROUND((RAND())*2) WHEN 0 THEN ROUND((RAND())*9) WHEN 1 THEN CHAR(ROUND((RAND())*25)+97) ELSE CHAR(ROUND((RAND())*25)+65) END,
CASE ROUND((RAND())*2) WHEN 0 THEN ROUND((RAND())*9) WHEN 1 THEN CHAR(ROUND((RAND())*25)+97) ELSE CHAR(ROUND((RAND())*25)+65) END,
CASE ROUND((RAND())*2) WHEN 0 THEN ROUND((RAND())*9) WHEN 1 THEN CHAR(ROUND((RAND())*25)+97) ELSE CHAR(ROUND((RAND())*25)+65) END,
CASE ROUND((RAND())*2) WHEN 0 THEN ROUND((RAND())*9) WHEN 1 THEN CHAR(ROUND((RAND())*25)+97) ELSE CHAR(ROUND((RAND())*25)+65) END,
CASE ROUND((RAND())*2) WHEN 0 THEN ROUND((RAND())*9) WHEN 1 THEN CHAR(ROUND((RAND())*25)+97) ELSE CHAR(ROUND((RAND())*25)+65) END,
CASE ROUND((RAND())*2) WHEN 0 THEN ROUND((RAND())*9) WHEN 1 THEN CHAR(ROUND((RAND())*25)+97) ELSE CHAR(ROUND((RAND())*25)+65) END,
CASE ROUND((RAND())*2) WHEN 0 THEN ROUND((RAND())*9) WHEN 1 THEN CHAR(ROUND((RAND())*25)+97) ELSE CHAR(ROUND((RAND())*25)+65) END
) AS rand_str;
其中+97就是产生小写字母a-z,+65就是产生大写字母A-Z。
第一个博主暂时看不懂,介绍下第二个吧。mysql中有一个随机函数rand(),会生成大于等于0,小于1(0到1)之间的小数。0到1的随机数乘以一个我们要随机范围,然后取整就可以,mysql中有round和floor函数都可以把小数变为整数。
FLOOR(X)
返回不大于X的最大整数值。
ROUND(X,D)
返回参数X的四舍五入的有D为小数的一个数字。如果D为0,结果将没有小数点或小数部分。
例如我们要0-99的随机数,只要下面的sql语句就可以了。
select floor(rand()*100);
1到99的随机数就是
select floor(1+rand()*99);