在 C# 应用程序上,我需要创建唯一的促销代码。
促销代码将存储在 SQL 表中 (SQL Server 2012)。
最初我想到了 GUIDS,但他们太渴望提供给用户了。
我正在考虑产生 52 521 875 个独特组合的 6 个字母数字代码。
你怎么看?
但是如何生成唯一的代码呢?我正在考虑:
使用随机;
使用当前日期时间的刻度
预先生成数据库中的所有代码并随机选择... 这种方法存在占用两个多空间的问题。
生成随机唯一代码的好方法是什么?
更新 1
对于 1 中的方法,我提出了以下 C# 代码:
Random random = new Random();
Int32 count = 20;
Int32 length = 5;
List<String> codes = new List<String>();
Char[] keys = "ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789".ToCharArray();
while (codes.Count < count) {
var code = Enumerable.Range(1, length)
.Select(k => keys[random.Next(0, keys.Length - 1)]) // Generate random char
.Aggregate("", (e, c) => e + c); // Join into a string
codes.Add(code);
}
更新 2
String source = "ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
while (codes.Count < count) {
length = 5;
StringBuilder builder = new StringBuilder(5);
while (length-- > 0)
builder.Append(source[random.Next(source.Length)]);
codes.Add(builder.ToString());
}
您认为哪种方法更快?
谢谢你, 米格尔
最佳答案
Eric Lippert 展示了如何使用 multiplicative inverse混淆顺序键。基本上,这个想法是生成顺序 key (即 1、2、3、4 等),然后混淆它们。
我在我的文章系列 Obfuscating Sequential Keys 中展示了一种更复杂的方法.
这种方法的美妙之处在于 key 随机出现,但您只需跟踪一个数字:要生成的下一个顺序值。
YouTube 使用类似的技术来生成他们的视频 ID。
关于c# - 生成简短的随机唯一促销代码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21973726/