MySQL生成随机字符串的三种方法
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL生成随机字符串的三种方法相关的知识,希望对你有一定的参考价值。
参考技术A 比如说,要生成一个10位的随机字符串,可以使用如下语句:运行结果:
该语句只能生成最长32位(但只有0~9,a~f共16种字符)的字符串,如果需要更长的字符,可以使用 concat 函数连接多个字符串,如下所示:
这个语句可以生成长度为42个字符的字符串。
运行结果:
因为 uuid() 函数返回的字符串中会包含特殊字符 "-" , 所以我们需要通过 replace 函数将这个特殊字符全部替换掉。这种方式会得到一个32位的字符串,如果有长度要求,可以用substring或concat函数裁剪或拼接。
运行结果:
数组的三种随机排序方法
第一种、利用数组自带的sort方法(下面是完整代码)
这种方法是利用随机出一个正数或者负数来让数组里面的内容两两对比,是正数就是顺序,是负数则是倒序,这种方法的缺点就是随机性不高,不能完全随机,因为是两两对比,所以最后一个数在最后的可能性较大。
第二种、利用递归函数对比(下面是完整代码)
递归的方法是利用递归函数的自调,定义一个随机数index(因为定了向下取整,所以范围为0~8)作为随机下标,然后将它对应的数从数组中取下压入到result数组中,从而实现随机排序,定义if判断,如果cloneArr的长度为空的话,则退出循环,这种随机的随机性很好,但是代码性能不太友好。
第三种、洗牌算法(推荐)
下面是完整代码:
洗牌算法呢是利用随机出的index下标对应的数,与数组从前到后相互切换,所以称为洗牌,代码运行效率相比前面几种高,随机性也很大。在这强烈推荐。
以上是关于MySQL生成随机字符串的三种方法的主要内容,如果未能解决你的问题,请参考以下文章