我正在开发一个允许我为员工生成随机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)
Run Code Online (Sandbox Code Playgroud)
`
6个integeres生成999999个数字.只需在表格中写下所有可用的内容即可.然后随机选择一个并删除它:
WITH cte AS (
SELECT TOP (1) number
FROM available
ORDER BY NEWID()
)
DELETE FROM cte
OUTPUT DELETED.number;
Run Code Online (Sandbox Code Playgroud)
这比尝试生成随机和检查可用性更可靠.如果您的组织已经拥有999998名员工,那么尝试随机生成一个仍然可用的员工将需要很长时间......
| 归档时间: |
|
| 查看次数: |
373 次 |
| 最近记录: |