通常我们生成唯一序列号的时候喜欢把时间作为序列号的其中,但时间序列号的长度为15,加上其他诸如userid,商户merchantid等长度达到50~60位,这样导致我们的序列号就非常长导致。
1,存放时占用空间大,
2,查询时效率慢
我们是不是可以把时间序列号变短呢?
我们知道:
根据ascII编码表:
小写字符a(97) 使用不同存储时的编码长度
二进制:01100001
八进制:141
十进制:97
十六进制:61
可以看出,随着进制的增高,字符的长度也会越来越短,如果我们拿我们常用的0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ这个62个字符作为编码,那么62进制就可以表示了。
再进行编码前,我搜了一下git,上面已经有代码实现了(base62),我就不再实现一遍了,代码如下:
1.编码,将long型转换为62进制字符串
/**
* Encodes a decimal value to a Base62 String
.
*
* @param b10
* the de