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

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

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

在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

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

icon_wink.gif icon_neutral.gif icon_mad.gif icon_twisted.gif icon_smile.gif icon_eek.gif icon_sad.gif icon_rolleyes.gif icon_razz.gif icon_redface.gif icon_surprised.gif icon_mrgreen.gif icon_lol.gif icon_idea.gif icon_biggrin.gif icon_evil.gif icon_cry.gif icon_cool.gif icon_arrow.gif icon_confused.gif icon_question.gif icon_exclaim.gif 

一键脚本 SSH攻击 IP查询 博客历程 留言本 文章归档 网站地图 谷歌地图
托管于阿里云&七牛云. 已加入博客联盟. 浙ICP备13025236号.
Copyright © 2010-2016 虫虫开源 All Rights Reserved.