zoukankan      html  css  js  c++  java
  • mysql获取随机字符串和随机数的方法

    在我们开发的过程中,我们可能会需要在表中随机生成一些数据以供我们进行相应的测试。

    就像我之前发的“mysql创建存储过程向数据表中加入规定条数的数据

    那么我们应该怎样生成随机的字符串和随机数字呢?

    下面我们来进行讨论。

    1、生成随机数字。

      我们生成的随机数字肯定不是没有范围的。我们会设置随机数字的一个范围。比如1-100.

    那,我们就来讨论一下随机生成1-100.的方法吧。

    首先,他是随机的我们会联想到这个函数:rand().

    然后,我们知道rand()这个函数生成的是0-1之间的随机数。

    所以,我们可以利用rand()的这个特性生成我们想要的区间的随机数。(比如1-100)

      mysql中我们可以这样做:select floor(rand()*100);

      那如果,我想要生成50-100的随机数该怎么办呢?

    我们可以这样做:使用公式=RAND()*(最大值-最小值)+最小值

      在mysql中我们这样实现:select floor(rand()*(100-50)+50);

    2、生成随机字符串。

      这里如果是生成随机的小写字母+数字的话我们可以用以下这个简便方法做。(利用md5函数进行实现)

      在mysql中这样实现:select substring(md5(rand()),1,10);

      以上函数实现,随机取得小写字母+数字的10位字符串。

      当然还有比较严谨的方法(现在MySQL中创建自定义函数,然后再调用它),如下:

    DELIMITER //

    DROP FUNCTION IF EXISTS `rand_string` //

    CREATE FUNCTION `rand_string`(n INT) RETURNS varchar(255) CHARSET utf8
    BEGIN

      DECLARE chars_str varchar(255) DEFAULT 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';

        DECLARE return_str varchar(255) DEFAULT '';

        DECLARE i INT DEFAULT 0;

        WHILE i < n DO

        SET return_str = concat(return_str,substring(chars_str , FLOOR(1 + RAND()*62 ),1));

        SET i = i + 1;

        END WHILE;

        RETURN return_str;

    END//

    再对这个自定义函数进行调用。select rand_string(10),就生成了10位的随机大小写字母+数字的字符串。

  • 相关阅读:
    【springboot】@Valid参数校验
    【springboot】事务处理
    【springboot】过滤器、监听器、拦截器,Aspect切片
    【java web】过滤器、拦截器、监听器的区别
    【java web】监听器listener
    【java web】拦截器inteceptor
    【java web】过滤器filter
    【权限管理】Apache Shiro和Spring Security的对比
    【面试题】挑战10个最难回答的Java面试题(附答案)
    【面试题】反向面试
  • 原文地址:https://www.cnblogs.com/573734817pc/p/10677838.html
Copyright © 2011-2022 走看看