首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用未在数据库中列出的C#生成随机数?

如何使用未在数据库中列出的C#生成随机数?
EN

Stack Overflow用户
提问于 2016-07-28 21:29:25
回答 1查看 566关注 0票数 0

我正在开发一个应用程序,该应用程序允许我为员工生成随机ID号(6个整数),但我想知道如何使用C#生成这些随机数,并且不会重复SQL数据库中其他员工已经使用的号码。下面是用SQL编写的代码:

代码语言:javascript
复制
declare @unique_UID varchar(6)

select @unique_UID = Right(ABS(CAST(CAST(NEWID() AS VARBINARY) AS INT)), 6)

while exists (select 1 from dbo.tblUserID 

   where @unique_UID = UserID_UID 
         and len(@unique_uid) = 6
         and @unique_UID <> @parm_User_Pin)(
         select @unique_UID = Right(ABS(CAST(CAST(NEWID() AS VARBINARY) AS INT)), 6)

`

EN

回答 1

Stack Overflow用户

发布于 2016-07-28 21:41:40

6个整数等于999999个数字。只需将所有可用的数据写在一个表中。然后随机选择一个并删除它:

代码语言:javascript
复制
  WITH cte AS (
    SELECT TOP (1) number
    FROM available
    ORDER BY NEWID()
  )
  DELETE FROM cte
  OUTPUT DELETED.number;

这比尝试生成随机和检查可用性更可靠。如果您的组织已经有999998名员工,尝试随机生成仍可用的员工将需要很长时间……

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/38637905

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档