之前看到的写法是这样
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 stemp = concat(stemp, right(concat(pow(10,stempcounts),),stempcounts));
end if;
return stemp;
end$$
delimiter ;
