我需要为我的应用程序生成唯一的ID。当我使用(UUID.randomUUID()).toString()
时,我得到了一个代码(认为这是唯一的),这是非常冗长的。
当我们使用Java时间戳或随机字符串生成代码时,我不确定它有多独特。
我需要生成唯一的代码,只有8-10个字符的长度(阿尔法-数字)。怎么弄成这样?我正在使用MySQL数据库。
在数据库端生成唯一的代码是最好的方法,还是我们可以在Java中生成如此短的(但却是唯一的)代码?
任何使用示例代码的建议都将非常有用。
发布于 2012-01-30 07:24:41
我使用来自RandomStringUtils.randomAlphanumeric()
的commons-lang
方法来实现这一点:
import org.apache.commons.lang.RandomStringUtils;
public static final int ID_LENGTH = 10;
public String generateUniqueId() {
return RandomStringUtils.randomAlphanumeric(ID_LENGTH);
}
如果使用Maven,请确保已将commons-lang
添加到项目的依赖项中:
<dependency>
<groupId>commons-lang</groupId>
<artifactId>commons-lang</artifactId>
<version>2.6</version>
</dependency>
在数据库端生成唯一的代码是最好的方法,还是我们可以在java中生成如此短的(但却是唯一的)代码?
这取决于你和你的项目。id生成是业务逻辑的一部分吗?如果是和所有逻辑都写在Java上,那么就把它写在Java上。如果全部或部分逻辑委托给数据库,那么在那里生成id (但在本例中,您将对特定数据库有很强的依赖性)。
发布于 2012-01-30 08:12:13
你有什么具体的限制需要考虑吗?比如跨应用的唯一性?因为否则,MySQL本身就能够生成ID,您所需要做的就是定义一个autoincrement
列,而不是在插入时指定它(也就是说,为它插入一个NULL
值)--这将使MySQL填充下一个可用的ID,该ID是唯一的,并且不需要您的工作。
它不会是字母数字字符串(我不确定是指定为需求还是限制),但是如果您所需要的只是唯一性,它就足够了。8-10个字母数字字符不足以保证随机生成的字符串的唯一性,因此您必须对数据库执行插入检查。
发布于 2012-01-30 07:27:06
在数据库端生成唯一的代码是最好的方法,还是我们可以在Java中生成如此短的(但却是唯一的)代码?
数据库被设计成能够在需要时生成唯一的ID。我怀疑你(或我)可能编码的任何东西都是“更好”的变体。
https://stackoverflow.com/questions/9060428
复制相似问题