您的位置:首页 > 其它

记录学习的点滴(MyBatis中插入操作返回主键)

2017-03-20 15:08 405 查看

实体类UserInfo,属性String userName,String password,int userCode,int userId

1.ORACLE数据库

1-1自增主键

要在oracle实现自增主键

CREATE SEQUENCE IF_KIKAKU.SEQ_USER_ID_WING
INCREMENT BY 1
START WITH 1
MAXVALUE 999999999
NOMINVALUE
NOCYCLE
NOORDER
NOCACHE
/


mapper.xml

利用IF_KIKAKU.SEQ_USER_ID_WING.NEXTVAL获取要插入数据的主键。

<insert id="getPrimaryKey" parameterType="com.test.model.UserInfo">
<selectKey keyProperty="userId" order="BEFORE" resultType="java.lang.Integer">
select IF_KIKAKU.SEQ_USER_ID_WING.NEXTVAL from DUAL
</selectKey>
INSERT INTO if_kikaku.test_user_m (
user_id,
user_cd,
password
) VALUES (
${userId},
${userCode},
#{password}
)
</insert>

parameterType:执行insert操作sql语句的参数类型。

keyProperty:将查询到的主键值设置到parameterType指定对象的哪个属性。

order:标签<selectKey>内的sql语句相对于insert语句执行的顺序。BEFORE:insert语句执行之前。AFTER:insert语句执行之后。

1-2UUID

用oracle自带的SYS_GUID()方法获取随机的GUID作为主键。

<insert id="方法名" parameterType="实体类">
<selectKey keyProperty="实体类属性" order="BEFORE" resultType="java.lang.Integer">
select SYS_GUID() from DUAL
</selectKey>
INSERT INTO if_kikaku.test_user_m (
主键,
...
) VALUES (
${实体类属性},
...
)
</insert>

2.MYSQL数据库

2-1自增主键

user_id not null auto_increment

mapper.xml

利用mysql的LAST_INSERT_ID()方法获取insert操作后的主键,这点和oracle不太一样,oracle是先获取主键值,再执行insert操作。

单单执行select LAST_INSERT_ID()语句只会返回0。

<insert id="getPrimaryKey" parameterType="com.test.model.UserInfo">
<selectKey keyProperty="userId" order="AFTER" resultType="java.lang.Integer">
select LAST_INSERT_ID()
</selectKey>
INSERT INTO if_kikaku.test_user_m (
user_cd,
password,
user_nm,
upd_time,
ins_time
) VALUES (
${userCode},
#{password},
#{userName},
sysdate(),
sysdate()
)
</insert>

2-2UUID

<insert id="方法名" parameterType="实体类">
<selectKey keyProperty="实体类属性" order="BEFORE" resultType="java.lang.Integer">
select UUID()
</selectKey>
INSERT INTO if_kikaku.test_user_m (
主键,
...
) VALUES (
${实体类属性},
...
)
</insert>

获取主键的调用

public void getPrimaryKey(){
UserInfo user = new UserInfo("name", "pawd", 4536);
myTestService.getPrimaryKey(user);
System.out.println("新插入记录的主键是:" + user.getUserId());
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: