(2016-09-01)SQL批量生成随机字符串

/*----------------------------------批量生成随机的字符串----------------------------------*/
--如果在已知数据库中存在GetRandStr这个存储过程,则删除(为了方便反复执行这段代码)
if exists(select * from sys.objects where name=‘GetRandStr‘ and type=‘P‘)
drop proc GetRandStr
go
--随机字符串存储过程
create proc GetRandStr
-- @count是随机字符串个数,@no则是最终生成的随机字符串
(@count int,@no varchar(1000) output)
as
begin
[email protected]是每次随机的字符累加的值
declare @randomstr varchar(1000)
[email protected]是产生随机字符的字符序列
declare @charpool varchar(1000)
-- @i是循环次数
declare @i int
[email protected] 是产生随机字符的位置
declare @counter integer
--设置随机序列
set @charpool=‘12345678910AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz‘
--循环初始值
set @i=1
-- 随机字符串初始值
set @randomstr=‘‘
--循环
while @i<@count
begin
here:
--产生随机字符位置 (0-62的整数)
set @counter=CAST(RAND()*100/1.6 as integer)
-- 如果@counter = 0 就重新生成随机数
if @counter<1 goto here
set @[email protected]+SUBSTRING(@charpool,@counter,1)
--循环递增
set @[email protected]+1
end
--最后将生成的六个随机字符加上两个固定字符‘KY‘,组成所需的随机字符串
set @no=‘QQ‘+LEFT(@randomstr,ISNULL(@count,180))
return
end
go
--调用:比如要生成10个随机字符串
declare @p int
set @p=1
while @p<=10
begin
declare @substring varchar(8000)
-- 调用存储过程
exec GetRandStr 8,@substring output
-- 输出随机字符串
print @substring
set @[email protected]+1
end

时间: 2024-11-07 00:13:32

(2016-09-01)SQL批量生成随机字符串的相关文章

SQL生成随机字符串

1.SQLserve生成随机字符串 SELECT replace(newid(), '-', '')

生成随机字符串的几种常用方式

写在前面 今天在学习数据库的时候想随机生成一些数据来插入到数据表中,但是一时想不起来如何生成随机内容,就整理了之前学过的一些生成随机字符串的命令,以备不时之需,希望对各位有所帮助. 生成随机字符串的几种方式 1,利用系统变量RANDOM生成随机数 [[email protected] ~]# echo $RANDOM  生成随机数 [[email protected] ~]# echo $((RANDOM%100+1)) 生成1-100内的随机数(取余法) 2,利用openssl生成随机字符串,

.net生成随机字符串

生成随机字符串的工具类: /// <summary> /// 随机字符串工具类 /// </summary> public class RandomTools { /// <summary> /// 随机系数 /// </summary> public static int _RandIndex = 0; #region 获取某个区间的一个随机数 /// <summary> /// 获取某个区间的一个随机数 /// </summary>

[PHP]利用openssl_random_pseudo_bytes和base64_encode函数来生成随机字符串

openssl_random_pseudo_bytes函数本身是用来生成指定个数的随机字节,因此在使用它来生成随机字符串时,还需要配合使用函数base64_encode.如下所示: public static function getRandomString($length = 42) { /* * Use OpenSSL (if available) */ if (function_exists('openssl_random_pseudo_bytes')) { $bytes = openss

PHP 生成随机字符串与唯一字符串

说明:生成随机字符串用到的方法有 mt_rand() 生成唯一字符串用到的方法有 md5(),uniqid(),microtime() 代码: 1 <?php 2 /* 3 * 生成随机字符串 4 * @param int $length 生成随机字符串的长度 5 * @param string $char 组成随机字符串的字符串 6 * @return string $string 生成的随机字符串 7 */ 8 function str_rand($length = 32, $char =

C# 生成随机字符串

#region 生成随机字符串 /// <summary> /// 生成随机字符串 /// </summary> /// <param name="codeCount"></param> /// <param name="allChar"></param> /// <returns></returns> public static string CreateRandomC

python 生成随机字符串 和随机数字

生成随机字符串: ''.join(random.sample(string.ascii_letters + string.digits, 8)) //字符串中不会重复 for _ in range(8): s += random.choice(string.ascii_letters + string.digits) //字符串可以重复 生成随机浮点数 random.uniform(10, 20) 生成随机整数 random.randint(12, 20) 原文地址:https://www.cn

PHP生成随机字符串与唯一字符串

代码如下: <?php /* * 生成随机字符串 * @param int $length 生成随机字符串的长度 * @param string $char 组成随机字符串的字符串 * @return string $string 生成的随机字符串 */ function str_rand($length = 32, $char = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ') { if(!is_int($le

Python生成随机字符串

利用Python生成随机域名等随机字符串. #!/usr/bin/env python# -*- coding: utf-8 -*- from random import randrange, choice from string import ascii_lowercase as lc from sys import maxsize from time import ctime tlds = ('com', 'edu', 'net', 'org', 'gov') for i in range(