至少有下列要求
- 是散列而且随机的,至少不会被猜到序列规则
- 是永不重复的,如果生成一次去验证是否存在,那效率是不是太低?
回复内容:
至少有下列要求
- 是散列而且随机的,至少不会被猜到序列规则
- 是永不重复的,如果生成一次去验证是否存在,那效率是不是太低?
推荐参考mongodb的ObjectId生成机制。 ObjectId一共12个字节
技术上面应用了三层结构,AJAX框架,URL重写等基础的开发。并用了动软的代码生成器及数据访问类,加进了一些自己用到的小功能,算是整理了一些自己的操作类。系统设计上面说不出用什么模式,大体设计是后台分两级分类,设置好一级之后,再设置二级并选择栏目类型,如内容,列表,上传文件,新窗口等。这样就可以生成无限多个二级分类,也就是网站栏目。对于扩展性来说,如果有新的需求可以直接加一个栏目类型并新加功能操作
- 4字节的时间戳,放在第一部分可以使ObjectId "大致"遵循时间顺序,保证不同秒数生成的ID一定不重复
- 3字节的机器ID,默认通过机器的各种基础信息hash而来,保证同一秒不同机器生成的ID一定不重复
- 2字节的进程号,保证同一秒同一机器不同进程生成的ID一定不重复
- 3字节的自增,在同一秒内自增,保证同一秒同一机器同一进程内生成的16777216个 ID一定不重复
可不可以使用UUID,如果想换成数字的话,那就做下转换。
可能数字会比较大,要自己定义下规则,缩小。









