snow8261 2012-08-24 15:53
浏览 395
已采纳

请教一个ID生成的问题,对于同一个字符串,每次生成一样的数字ID,对于不同的字符串,每次都生成不一样的ID

如题,请问大家有没有什么想法?有没有成熟的解决方案。谢谢。

  • 写回答

10条回答 默认 最新

  • chiyxme 2012-08-26 10:54
    关注

    目前在一个短链接算法中,我使用的是如下的方案:

    1,为字符串分别使用3个不同的hash算法,生成三个hash值(用于定位)
    2,通过3个hash值去数据库中查询是否存在该字符串的记录。(不用MD5是因为MD5是值本身是字符串序列,查找效率地)
    3. 不存在记录则通过自增ID,为该字符串分配一个唯一的ID序列,然后将ID,3个hash值,字符串本身存入数据库

    只有3个hash值不同时相等(基本不可能)ID值就是唯一的,而且通过设置自增ID的初始值,可以精确指定ID值的范围

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(9条)

报告相同问题?

悬赏问题

  • ¥15 拟通过pc下指令到安卓系统,如果追求响应速度,尽可能无延迟,是不是用安卓模拟器会优于实体的安卓手机?如果是,可以快多少毫秒?
  • ¥20 神经网络Sequential name=sequential, built=False
  • ¥16 Qphython 用xlrd读取excel报错
  • ¥15 单片机学习顺序问题!!
  • ¥15 ikuai客户端多拨vpn,重启总是有个别重拨不上
  • ¥20 关于#anlogic#sdram#的问题,如何解决?(关键词-performance)
  • ¥15 相敏解调 matlab
  • ¥15 求lingo代码和思路
  • ¥15 公交车和无人机协同运输
  • ¥15 stm32代码移植没反应