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

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

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值