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

就像我之前发的“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位的随机大小写字母+数字的字符串。

mysql获取随机字符串和随机数的方法的更多相关文章

  1. php获取随机字符串的几种方法

    方法一:shuffle函数(打乱数组)和mt_rand函数(生成随机数,比rand速度快四倍) /** * 获得随机字符串 * @param $len 需要的长度 * @param $special ...

  2. PHP获取随机字符串的两种方法

    <?php /** * 随机返回字符串 * @param number 返回字符串长度 * @param string 从哪些字符串中随机返回,已设置默认字符串,可空 * @return str ...

  3. go golang 判断base64数据 获取随机字符串 截取字符串

    go golang 判断base64数据 获取随机字符串 截取字符串 先少写点,占个坑,以后接着加. 1,获取指定长度随机字符串 func RandomDigits(length int) strin ...

  4. php获取随机字符串

    获取随机字符串 /** * 获取随机字符串 * @param int $randLength 长度 * @param int $addtime 是否加入当前时间戳 * @param int $incl ...

  5. MySQL查询随机数据的4种方法和性能对比

    从MySQL随机选取数据也是我们最常用的一种发发,其最简单的办法就是使用”ORDER BY RAND()”,本文介绍了包括ORDER BY RAND()的4种获取随机数据的方法,并分析了各自的优缺点. ...

  6. Python学习总结7:随机字符串和随机数

    Python生成随机数与随机字符串,需要import random模块.random模块最常用的几个函数如下: 1. random.random(a, b) 用于生成一个0到1的随机符点数: 0 &l ...

  7. js生成随机字符串或者随机数

    //返回一个指定范围内的随机数 function createRandomNum(Min,Max){ let Range = Max - Min; let Rand = Math.random(); ...

  8. Mysql 自定义随机字符串

    前几天在开发一个系统,需要用到随机字符串,但是mysql的库函数有没有直接提供,就简单的利用现有的函数东拼西凑出随机字符串来.下面简单的说下实现当时. 1.简单粗暴. select ..., subs ...

  9. php 获取随机字符串(原创)

    //获取随机数字字母字符串 function get_rand_str($len=8){ $randArr=array_merge(range(0,9),range('a','z'),range('A ...

随机推荐

  1. Java编码常见的Log日志打印问题

    前言 本文总结了作者在Java代码检视中遇到的一些关于日志打印的问题,并给出修改建议.因能力有限,难免存在错漏,欢迎指正. 一. 不规范的异常打印 使用slf4j日志组件时,logger.error( ...

  2. Java过滤器处理Ajax请求,Java拦截器处理Ajax请求,java 判断请求是不是ajax请求

    Java过滤器处理Ajax请求,Java拦截器处理Ajax请求,java 判断请求是不是ajax请求   Java过滤器处理Ajax请求,Java拦截器处理Ajax请求,拦截器Ajax请求 java ...

  3. CSS设置浏览器滚动条样式

    /*定义滚动条高宽及背景 高宽分别对应横竖滚动条的尺寸*/ ::-webkit-scrollbar { width: 5px; height: 110px; background-color: #F5 ...

  4. spring学习笔记-AOP

    1.aop:aspect oriented programming 面向切面编程 2.aop在spring中的作用:   提供声明式服务(声明式事务) 允许用户实现自定义切面 3.aop:在不改变原有 ...

  5. 解决org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)错误

    我调这个bug调了一天多,在网上搜索的检查namespace,package等,都没有错.错误提示是没有找到xml文件,我就纳闷了,为什么找不到呢?后来才发现,原来是resource中奇怪的目录为题, ...

  6. 第七天 py

  7. 第六天 py 加法练习

    其实就是while的用法!   该看第65 啦

  8. 第五天 py if使用

    if 的结果缩进  用个Tab 缩进四个空格就好了

  9. Hadoop fs -put bandwidth 暴力版

    /* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreem ...

  10. Python学习之旅(二十)

    Python基础知识(19):面向对象高级编程(Ⅱ) 定制类 形如“__xx__”的变量或函数在Python中是有特殊用途的 1.__str__ 让打印出来的结果更好看 __str__:面向用户:__ ...