产生随机密码的sql存储过程

项目中碰到要产生随机密码,而密码有不可以重复,所以找了些资料,写了这么一个存储过程。row是要生成几个密码。active是活动编号,FirstChar是指定的密码首字母.里面较好的利用了sql newid产生随机数,又利用了不重复的索引来产生数据。想想在。net里面要考虑到不重复产生密码是多么繁杂的事情啊。这样一个过程就可以解决。还可以生成核对时的数据库,不能说构思不巧妙。

[@more@]

SET QUOTED_IDENTIFIER ON
GO
SET ANSI_NULLS ON
GO

CREATE PROCEDURE gen_PrintPass
(
@row int output,
@active int,
@firstChar char(1)
)

AS

WHILE @row >0
BEGIN
SET ROWCOUNT @row
INSERT printPass SELECT
passCode = @firstChar+RIGHT(100000000+CONVERT(bigint,ABS(CHECKSUM(NEWID()))),9),active=@active
From syscolumns c1,syscolumns c2
SET @row = @row - @@ROWCOUNT
END


GO
SET QUOTED_IDENTIFIER OFF
GO
SET ANSI_NULLS ON
GO

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/77544/viewspace-1003528/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/77544/viewspace-1003528/

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值