您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

Mysql 生成固定位数的随机数

2024/5/4 1:19:18发布30次查看
项目中需要动态随机生成一些固定位数的随机数,如8位,5位等。
之前看到的写法是这样
 round(round(rand(),5)*100000)
这样写不太准确,有几率出现4位的情况,rand() 函数是取  0 ~ 1(无限接近) 的随机函数
如果 某此随机数取出的 是  0.05321
那么这样转化出来的就是 5321 ,只有4位。
如果能用一个函数包装一下,取完数值后发现位数不对的时候,就补位进去就比较完美了。
下面是我改的一个函数,不过缺点是 生成的函数位数不能超过20位。当然改一改也是可以了。
delimiter $$
use `prvecard`$$
drop function if exists `getrand`$$
create definer=`pecard`@`%` function `getrand`(counts integer) returns varchar(20) charset utf8
begin
       declare stemp varchar(20);
    declare stempcounts integer;
       set stemp = concat( round(round(rand(),counts)*(pow(10,counts))),);
if(char_length(stemp)set stempcounts = counts - char_length(stemp);
      set stemp = concat(stemp, right(concat(pow(10,stempcounts),),stempcounts));
    end if;
return stemp;
end$$
delimiter ;
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product