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

时间:2016-07-28 13:29:25

标签: c# sql sql-server random

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

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)

`

1 个答案:

答案 0 :(得分:5)

6 integeres生成999999个数字。只需在表格中写下所有可用的内容即可。然后随机选择一个并删除它:

  WITH cte AS (
    SELECT TOP (1) number
    FROM available
    ORDER BY NEWID()
  )
  DELETE FROM cte
  OUTPUT DELETED.number;

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