记录学习的点滴(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获取要插入数据的主键。
parameterType:执行insert操作sql语句的参数类型。
keyProperty:将查询到的主键值设置到parameterType指定对象的哪个属性。
order:标签<selectKey>内的sql语句相对于insert语句执行的顺序。BEFORE:insert语句执行之前。AFTER:insert语句执行之后。
1-2UUID
用oracle自带的SYS_GUID()方法获取随机的GUID作为主键。
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。
2-2UUID
获取主键的调用
public void getPrimaryKey(){
UserInfo user = new UserInfo("name", "pawd", 4536);
myTestService.getPrimaryKey(user);
System.out.println("新插入记录的主键是:" + user.getUserId());
}
实体类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());
}
相关文章推荐
- MyBatis魔法堂:Insert操作详解(返回主键、批量插入)
- MyBatis魔法堂:Insert操作详解(返回主键、批量插入)
- mybatis 插入时返回刚插入记录的主键值 (Oracle作为数据库)
- MyBatis在insert插入操作时返回主键ID的配置
- MyBatis+MySQL 返回插入记录的主键ID
- MyBatis+MySQL 返回插入记录的主键ID
- MyBatis在insert插入操作时返回主键ID的配置
- Mybatis之Insert操作详解(返回主键、批量插入)
- mybatis 进行插入操作,如何返回主键问题
- 使用Mybatis时,在插入一条数据记录返回主键id值
- MyBatis学习 之 六、insert操作返回主键
- MyBatis+MySQL 返回插入记录的主键ID
- 【MyBatis框架点滴】——mybatis插入数据返回主键(mysql、oracle)
- MyBatis:Insert操作详解(返回主键、批量插入)
- MyBatis魔法堂:Insert操作详解(返回主键、批量插入)
- MyBatis+MySQL 返回插入记录的主键ID
- Java开发: Mybatis insert 插入记录后自动返回主键(Mybatis3.x)
- MyBatis在insert插入操作时返回主键ID的配置
- MyBatis魔法堂:Insert操作详解(返回主键、批量插入)
- MyBatis在insert插入操作时返回主键ID的配置