Oracle VARCHAR类型主键的使用(ibatis)

通常在设计表时,主键都设为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);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值