MyBatis Oracle 自增序列的实现方法
mybatisoracle自增序列的代码如下所示:
<insertid="insert"useGeneratedKeys="true"keyProperty="s_id"parameterType="xxxx"> <selectKeyresultType="int"order="BEFORE"keyProperty="s_id"> SELECTSEQ_TABLE.NEXTVALFROMdual </selectKey> INSERTINTO<spanstyle="font-family:Arial,Helvetica,sans-serif;">s_id</span><spanstyle="font-family:Arial,Helvetica,sans-serif;">,name,age</span> VALUES (#{s_id}#{name},#{age}) </insert>
resultType="int"返回的是一个int类型
keyProperty把返回值,赋值给:parameterType中对象的对象的属性,也就是xxxxx类中的s_id属性
useGeneratedKeys="true"keyProperty="s_id"
返回序列id,如果不需要,可以不填
下面看下mybatis配置oracle的主键自增长
mysql、sqlserver等数据库本身带有主键自增长像auto_increment的功能可以直接使用
useGeneratedKeys=”true”来实现,比如下面的配置
insertintos_user_auth(id,user_id,user_name)values(#{id},#{userid},#{username})
而oracle则不行,oracle主键自增长是通过sequence实现的,所以这种方式就不可以了,需要使用:
1.先通过sequence查出来id,再insert
selectyoursequence.nextvalasidfromdual insertintos_user_auth(id,user_id,user_name)values(#{id},#{userid},#{username})
2.直接insertsequence.nextval,如下
insertintos_user_auth(id,user_id,user_name)values(yoursequence.nextval,#{userid},#{username})