postgresql+Mybatis insert数据后返回主键id

postgresql+Mybatis insert数据后返回主键id

1.主键id存在序列的情况

可以使用如下方式:

 <insert id="insertUser">
    <selectKey resultType="int"  order="AFTER" keyProperty="pid" >
        SELECT nextval('tbl_user_pid_seq'::regclass) AS pid
    </selectKey>
    insert into tbl_user(name, age) values(#{name}, #{age})
</insert>

使用selectKey标签 after是指在insert之后获取id,‘tbl_user_pid_seq’是指序列名,在navicat中可以查看到:
在这里插入图片描述

2.主键id不存在序列的情况

可以使用如下方式:

<select id="insertData" parameterType="Map" resultType="long">
		insert
		into users
		(name,gender,age,remark)
		values(
		#{name},
		#{gender},
		#{age},
		#{remark})
		returning id
</select>

使用returning 可以返回执行insert语句之后的字段值。但是insert语句要放在select标签内执行。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

banmajio

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

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

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

打赏作者

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

抵扣说明:

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

余额充值