Mybatis系列笔记七——主键值回填

主键值回填

在数据库中插入数据时,有时我们是需要获取新数据的主键值。在 Mybatis 中支持主键 值回填,可以让我们更够更方便的获取新添加数据的主键值
Mybatis 中支持两种方法获取主键:

  • 获取自增主键的值。如:MySQL、SqlServer
  • 获取非自增主键的值。如 Oracle

获取自增主键值

  • 接口
void insertUsersGetKey(Users users);

局部配置

  • mapper
<!--添加用户获取主键值[自增]--> 
<insert id="insertUsersGetKey" useGeneratedKeys="true" keyProperty="userid"> 
	insert into users values(default ,#{username},#{usersex}) 
</insert>

全局配置

  • 全局配置文件
<settings> 
	<setting name="useGeneratedKeys" value="true"/> 
</settings>
  • mapper
<!--添加用户获取主键值[自增]--> 
<insert id="insertUsersGetKey" keyProperty="userid"> 
	insert into users values(default ,#{username},#{usersex}) 
</insert>

获取非自增主键值

<!--添加用户获取主键值[非自增] oracle[order:Before] mysql[order:after]--> 
<insert id="insertUsersGetKey"> 
	<selectKey order="AFTER" keyProperty="userid" resultType="int"> 
	<!--在 MySQL 数据库中获取插入数据的主键的值: SELECT LAST_INSERT_ID(),SELECT @@Identity 是 SELECT LAST_INSERT_ID()的同义 词。作用是相同的。 --> 
		SELECT LAST_INSERT_ID() 
	</selectKey> insert into users values(default ,#{username},#{usersex}) </insert>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

绿豆蛙给生活加点甜

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值