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条)

报告相同问题?

悬赏问题

  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable
  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)