标题:用户名是随机长度的随机字符串出现
只看楼主
good_good_study
Rank: 1
等 级:新手上路
帖 子:21
专家分:0
注 册:2007-11-24
 问题点数:0 回复次数:4 
用户名是随机长度的随机字符串出现
Declare @TempInt int
Set @TempInt=1
While @TempInt<100
Begin
insert into changying(userName)values('abcd')
Set @TempInt=@TempInt+1
End
go
我现在要把“abcd”变成一个随机的字符串
帮一下忙啊
搜索更多相关主题的帖子: 字符 随机 用户名 长度 
2007-12-15 18:08
purana
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:广东-广州
等 级:版主
威 望:66
帖 子:6039
专家分:0
注 册:2005-6-17
得分:0 
declare @t table(userName varchar(100))

Declare @TempInt int,@value varchar(100)
Set @TempInt=1

While @TempInt<100
Begin
    set @value=char(cast(rand()*26 as int)%26+97)
    insert into @t (userName) values(@value)
    Set @TempInt=@TempInt+1
End

select * from @t

--随机长度的..自己去考虑.

我的msn: myfend@
2007-12-15 19:06
orliubc
Rank: 1
等 级:新手上路
帖 子:73
专家分:0
注 册:2007-11-18
得分:0 
cast(rand()*26 as int)%26+97

这是怎么运算的,想不开哎

low water low live
2007-12-16 19:31
orliubc
Rank: 1
等 级:新手上路
帖 子:73
专家分:0
注 册:2007-11-18
得分:0 
cast(rand()*100 as int)%30

purana在吗?  麻烦你帮我解释下上面句子的返回值啊,%30 是怎么算的?
急啊!! 谢谢啊

low water low live
2007-12-18 12:37
关小彤
Rank: 1
等 级:新手上路
帖 子:114
专家分:0
注 册:2006-12-7
得分:0 
char(cast(rand()*26 as int)%26+97)
我是这样理解的:)
因为有26个字母,所以和26有关
(rand()*26 as int )%26产生一个从0-26的随机整数,因为a的ASCII码是97,所以要加上97。

就能够得到你想要的

[[italic] 本帖最后由 关小彤 于 2007-12-25 09:31 编辑 [/italic]]

2007-12-25 09:29



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-192647-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.106322 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved