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



实体类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());
	}






  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值