c# - 生成简短的随机唯一促销代码

标签 c# sql

在 C# 应用程序上,我需要创建唯一的促销代码。

促销代码将存储在 SQL 表中 (SQL Server 2012)。

最初我想到了 GUIDS,但他们太渴望提供给用户了。

我正在考虑产生 52 521 875 个独特组合的 6 个字母数字代码。

你怎么看?

但是如何生成唯一的代码呢?我正在考虑:

  1. 使用随机;

  2. 使用当前日期时间的刻度

  3. 预先生成数据库中的所有代码并随机选择... 这种方法存在占用两个多空间的问题。

生成随机唯一代码的好方法是什么?

更新 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/

相关文章:

mysql - SQL 在 SELECT 之后一次更新多行

mysql - 如何将数据库从数百 MB 的大型 SQL 文件导入到 MySQL

c# - 如何使用 C# 和 WinForm 创建 1 像素宽的窗口

c# - 如何从任意字符串生成有效的 Windows 文件名?

sql - 根据字符串中一组关键字的出现对 sql 结果进行排序

sql - 只读提交的数据

mysql - 如何实现连接运算符

c# - 如何为我的 linq 查询创建自定义存储表达式

c# - 我的应用程序不会在 .net 2.0 下运行,适用于 3.5

c# - 卡在 C# 中的 BinaryExpression