mysql随机字符串和数值的获取

发表时间:2012-11-05 17:15 | 分类:Mysql | 浏览:1,189 次

今天博主在坛子里头看到一位朋友的提问,要求是插入随机字符串。具体描述如下:

在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);

本文标签:

本文链接:http://www.sijitao.net/1167.html

欢迎您在本博客中留下评论,如需转载原创文章请注明出处,谢谢!

博客历程 留言本 文章归档 网站地图 谷歌地图 浙ICP备13025236号-1
托管于阿里云&七牛云 已加入博客联盟 浙公网安备 33021202000610号
Copyright © 2010-2017 虫虫开源 All Rights Reserved.