我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Mysql 中怎么生成固定位数的随机数

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Mysql 中怎么生成固定位数的随机数

这篇文章将为大家详细讲解有关Mysql 中怎么生成固定位数的随机数,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

项目中需要动态随机生成一些固定位数的随机数,如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 ` 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)<counts) THEN
   
      SET sTempCounts = counts - CHAR_LENGTH(sTemp);
      SET sTemp = CONCAT(sTemp, RIGHT(CONCAT(POW(10,sTempCounts),),sTempCounts));
    END IF;
   
      RETURN sTemp;
END$$

DELIMITER ;

关于Mysql 中怎么生成固定位数的随机数就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Mysql 中怎么生成固定位数的随机数

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

C++中怎么生成随机数

这篇文章将为大家详细讲解有关C++中怎么生成随机数,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。C++中常用rand()函数生成随机数,但严格意义上来讲生成的只是伪随机数(pseudo-ra
2023-06-17

Java中的随机数Random怎么生成

在Java中,可以使用Random类来生成随机数。以下是使用Random类生成随机数的示例代码:```javaimport java.util.Random;public class GenerateRandomNumber {public
2023-08-18

c++怎么生成随机数

在 c++ 中,可以使用 rand() 函数生成随机数,该函数返回一个 [0, rand_max] 范围内的伪随机整数,rand_max 为 2147483647。C++ 生成随机数如何生成随机数?在 C++ 中,可以使用 rand()
c++怎么生成随机数
2024-05-15

matlab怎么生成指定区间的随机数

在MATLAB中,你可以使用`rand`函数生成一个在(0,1)之间的随机数。如果你想生成一个在指定区间(a,b)之间的随机数,可以按照以下步骤:1. 生成一个(0,1)之间的随机数。2. 将该随机数与(b-a)相乘。3. 将结果加上a,以
2023-08-14

java中怎么随机生成整数

在Java中,可以使用java.util.Random类来生成随机整数。具体如下所示:import java.util.Random;public class RandomNumber {public static void main(S
java中怎么随机生成整数
2024-03-13

Android怎么生成随机数

这篇文章给大家分享的是有关Android怎么生成随机数的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。java文件package com.example.my_xm_bw_luowei;import android
2023-06-14

怎么在PHP中生成随机数

在PHP中,可以使用rand()函数来生成随机数。这个函数接受两个参数,分别是随机数的最小值和最大值。下面是一个示例代码:```php$min = 1;$max = 10;$randomNumber = rand($min, $max);e
2023-08-15

java怎么生成指定范围的随机小数

在Java中,可以使用`java.util.Random`类来生成随机小数。下面是一个示例代码,演示如何生成指定范围的随机小数:```javaimport java.util.Random;public class RandomDecima
2023-08-18

Python中怎么生成随机数与随机字符串

这篇文章将为大家详细讲解有关Python中怎么生成随机数与随机字符串,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。random.random()用于生成用于生成一个指定范围内的随机符点数,两
2023-06-17

php中生成随机数的函数

php中生成随机数的函数是 rand() 和 mt_rand()。rand() 生成伪随机整数,范围为 0 至 php_int_max,序列基于种子值生成。mt_rand() 生成梅森旋转伪随机整数,提供更好的随机性,需要显式设置种子值才能
php中生成随机数的函数
2024-04-29

excel怎么指定范围内生成随机数

在 Excel 中,可以使用 `RANDBETWEEN` 函数来生成指定范围内的随机数。具体步骤如下:1. 在 Excel 工作表的一个单元格中输入要生成随机数的范围的最小值,例如 A1 单元格输入 1。2. 在另一个单元格中输入要生成随机
2023-09-07

random中怎么随机生成10个数

这期内容当中小编将会给大家带来有关random中怎么随机生成10个数,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。生成10个随机数import randomnum = range(0, 100) #
2023-06-02

oracle怎么生成随机数据

在 oracle 中生成随机数据可以通过以下两种方法:random() 函数:生成 0 到 1 之间的随机浮点数,可结合 mod 函数生成整数随机数。dbms_random 包:提供各种随机数据生成函数,包括整数、字符串和日期随机生成。如何
oracle怎么生成随机数据
2024-05-21

vb怎么随机生成1到100随机数

在VB中,可以使用`Random`类来生成随机数。以下是一个生成1到100之间随机数的示例代码:```vbDim random As New Random()Dim randomNumber As Integer = random.Next
2023-08-16

oracle怎么生成随机整数

Oracle数据库中可以使用DBMS_RANDOM包来生成随机数,其中包括生成随机整数的函数。下面是一个使用DBMS_RANDOM包生成随机整数的示例:SELECT FLOOR(DBMS_RANDOM.VALUE(1, 100)) AS
oracle怎么生成随机整数
2024-04-09

Java怎么生成随机整数

本篇内容主要讲解“Java怎么生成随机整数”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java怎么生成随机整数”吧!1. java.util.Random这Random().nextInt(i
2023-06-30

编程热搜

目录