hibernate框架使用Stringuuid作为id生成策略问题
RT,假设时间点A、B,B在A之后,那么在B时间点生成的Stringuuid一定大于A时间点生成的么?感谢~...
RT,假设时间点A、B,B在A之后,那么在B时间点生成的Stringuuid一定大于A时间点生成的么?感谢~
展开
展开全部
看hibernate中uuid的生成代码
public Serializable generate() {
return new StringBuffer(36)
.append( format( getIP() ) ).append(sep)
.append( format( getJVM() ) ).append(sep)
.append( format( getHiTime() ) ).append(sep)
.append( format( getLoTime() ) ).append(sep)
.append( format( getCount() ) )
.toString();
}
IP和JVM相同的情况下B在A之后高位和地位时间都是根据System.currentTimeMillis()获取的,那么B在A之后,的情况下uuid在B时间点生成的肯定大一A时间点生成的。
更多追问追答
追问
那这个意思是指 如果我多个服务器做集群的话,就有可能出现B时间点生成小于A时间点生成的了吧?
追答
多服务器的情况下有可能啊,IP,JVM和System datetime都不统一,肯定会出现的。
展开全部
这个干嘛要比较,一般只用于一个唯一的标识,时间只是UUID的一部分
更多追问追答
追问
我的这张表数据量挺大(百万条)的,展示时的要求是按时间倒序,但是order by time太慢了,所以问了这个问题!
追答
uuid实现你说的比较有点麻烦 吧,它应该是基于字符串的比较,不然要转码才行,这个应该更费资,可以考虑把时间格式化再比较,一些数据库支持格式化成字符串或其它类型,这样是不是好一些
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询