首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在SQL中生成短的和唯一的字符串值。

在SQL中生成短的和唯一的字符串值。
EN

Stack Overflow用户
提问于 2017-05-05 17:24:06
回答 1查看 1.4K关注 0票数 0

我正在构建一个应用程序,它需要一个作为UserID的唯一标识符(例如A3D7sRt)。

在我的例子中,我已经指示不要只使用数字UserID,它应该是自动生成的。此外,用户id应该是6-8字符长。这是因为它必须容易记住。

在这里,使用GUID对我来说不是一个选项。因为GUID在本质上是HEX,所以与相同长度的字符串相比,我得到的唯一值将更少。

那么,在SQL中实现这一目的的有效方法是什么呢?此外,我不希望遇到频繁的唯一约束失败的异常。

然后使用此值登录到android移动客户端。登录过程中没有密码。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-05-05 18:23:43

基于Martin SmithZohar Peled的评论,我找到了一个解决方案。

  1. 拿一只比基尼(可能是你的主钥匙)
  2. 将其编码为BASE36
  3. 不能是0。使用较高的数字(或从开始)获得大于6个字符的输出长度

这里是T

代码语言:javascript
复制
DECLARE @Result VARCHAR(MAX) = ''
DECLARE @Val BIGINT = 101722230 

IF (@Val <= 1000000)
BEGIN
    Select 'Very Small ID Try With Large BIGINT' 
    return;
END

WHILE (@Val > 0)
BEGIN
    SELECT @Result = CHAR(@Val % 36 + CASE WHEN @Val % 36 < 10 THEN 48 ELSE 55 END) + @Result,
            @Val = FLOOR(@Val/36)
END

SElect @Result

输出

1OK9DI是上述代码的输出。(核实)

感谢每一个通过评论这个问题帮助我的人。

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

https://stackoverflow.com/questions/43810653

复制
相关文章

相似问题

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