通常在设计表时,主键都设为number类型,因为这样可以使用序列实现自增。但最近做的一个项目规定主键一点要用varchar类型。网上有好多种方法,基本上是用一个类,将机器码和其它一些什么 码的加到一起。生成一个不重复字符串等类似的方法。我觉得太复杂就都没有使用,就选择了两个简单方法:
1. 使用 system.currentTimeMillis() +“”
system.currentTimeMillis()的作用是返回当前的计算机时间,时间的表达格式为当前计算机时间和GMT时间(格林威治时间)1970年1月1号0时0分0秒所差的毫秒数。
用这个方法,在前期的手动插入表时,不存在任何问题。比如,在系统中添加一个用户。但做到后面有一个功能是 批量插入 (先关闭了自动提交,取得所有批量后,再提交)。这个时候就是提示 “违反唯一约束”。因为电脑的速度太快,在一个毫秒数内就加入了批量,所以就造成 主键ID 是一样成无法插入。
2. 使用 sequence
序列可以自增,只要每次都先获取下一个值再快也不会重复。但问题是sequence 生成的是数字。只用一个办法就可以解决,如下:
创建序列:
create sequence SEQ_AUDIT_ROLE
increment by 1
start with 2
maxvalue 999999999999999
minvalue 1;
mapper 插入数据
<insert id="addRoleInfo" parameterClass="auditRoleClass">
<selectKey resultClass="java.lang.String" keyProperty="roleId">
SELECT SEQ_AUDIT_ROLE.NEXTVAL AS roleId FROM DUAL
</selectKey>
insert into AUDIT_ROLE (ROLE_ID,...)
values(#roleId#,...)
</insert>
service:
public void insertRoleInfo(AuditRole auditrole) {
// auditrole.setRoleId(System.currentTimeMillis()+"");
String roleId = (String)getSqlMapClientTemplate().insert("AUDIT_ROLE.addRoleInfo", auditrole);
}
System.out.println("roleId:"+roleId);