java相关:MyBatis Oracle 自增序列的实现方法
发布于 2020-3-25|
复制链接
摘记: mybatis oracle 自增序列的代码如下所示:
```java
..
mybatis oracle 自增序列的代码如下所示:
```java
SELECT SEQ_TABLE.NEXTVAL FROM dual
INSERT INTO s_id,name,age
VALUES
(#{s_id} #{name}, #{age} )
```
resultType="int" 返回的是一个int类型keyProperty 把返回值,赋值给:parameterType中对象的对象的属性,也就是xxxxx类中的s_id属性
```java
useGeneratedKeys="true" keyProperty="s_id"
```
返回序列id,如果不需要,可以不填下面看下mybatis配置oracle的主键自增长mysql、sqlserver等数据库本身带有主键自增长像auto_increment的功能可以直接使用useGeneratedKeys=”true”来实现,比如下面的配置
```java
insert into s_user_auth (id,user_id, user_name) values(#{id},#{userid},#{username})
```
而oracle则不行,oracle主键自增长是通过sequence实现的,所以这种方式就不可以了,需要使用:1.先通过sequence查出来id,再insert
```java
select yoursequence.nextval as id from dual
insert into s_user_auth (id,user_id, user_name) values(#{id},#{userid},#{username})
```
2.直接insertsequence.nextval,如下
```java
insert into s_user_auth (id,user_id, user_name) values(yoursequence.nextval,#{userid},#{username})
```