sql随机产生姓名

declare  @firstNames  varchar( max)     /*  保存名的集合  */
declare  @lastNames  varchar( max)         /*  保存姓的集合  */

set@firstNames='芳,海,亮,红,君,军,俊,江,河,湖,波,杰,山,燕,阳,洋,涛,斌,彬,宾,微,伟,威,薇,刚,倩'/* 必须只有一个字 */
set @lastNames = '刘,方,王,李,赵,孙,钱,胡,易,黄,温,丁,周,魏,陈,曾,涂'    /* 必须只有一个字 */
declare @lastNamesLength int
declare @firstNamesLength int
set @lastNamesLength = (LEN(@lastNames- 1/ 2 + 1
set @firstNamesLength = (LEN(@firstNames- 1/ 2 + 1

declare @firstNameRandom int
declare @lastNameRandom int

declare @resultFullNames varchar(max)
set @resultFullNames = ''

declare @i int
set @i = 1
while(@i <= 1000)
begin
    set @firstNameRandom = CEILING(rand()*@firstNamesLength)
    set @lastNameRandom = CEILING(rand()*@lastNamesLength)
    /*
        产生第 1 个字,对于的 Index 为 1,注意:这里的 Index 最小值为 1。
        产生第 2 个字,对于的 Index 为 3,
        产生第 3 个字,对于的 Index 为 5,
        ...
    
*/
    set @resultFullNames = @resultFullNames + ( SUBSTRING(@lastNames@lastNameRandom * 2 - 11+ SUBSTRING(@firstNames@firstNameRandom * 2 - 11+ ',' )
    set @i = @i + 1
end
print @resultFullNames

 

转载于:https://www.cnblogs.com/AngelLee2009/archive/2011/10/31/2229716.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值