mybatis+pgsql 执行 insert 和 update 之后返回 id

2020-09-14 09:46:18 +08:00
 jiobanma

看到网上是这么写的

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

tbl_user_pid_seq 是一个序列,但是自己的库 id 没有序列,是自己写了一个 next_id 的函数。 并且因为需要,mybatis 的 parameterType 也不是一个 entity,而是一个 Map 这种时候 xml 该怎么写才能拿到 insert 之后的 id

2064 次点击
所在节点    Java
8 条回复
chihiro2014
2020-09-14 09:57:48 +08:00
用 JPA 就可以摆脱 XML 地狱了
ourslay
2020-09-14 10:19:05 +08:00
试试 spring data jdbc
yongle1117
2020-09-14 10:25:36 +08:00
之前遇到过这个问题,我们的解决办法是在 entity 上
@Id
@KeySql(genSql = PostgreGenSql.class, order = ORDER.AFTER)
@Column(insertable = false)
private Long id;



public class PostgreGenSql implements GenSql {

private static final String SQL = "SELECT currval('%s_id_seq'::regclass)";

@Override
public String genSql(EntityTable entityTable, EntityColumn entityColumn) {
return String.format(SQL, entityTable.getName().toUpperCase());
}

}
Takamine
2020-09-14 17:59:26 +08:00
……可以试试一个黑魔法,把<insert>标签改成<select>标签使用 pg 的 returning 来做。
jiobanma
2020-09-15 09:11:40 +08:00
@Takamine #4 我在网上也找到这个黑魔法了,现在用的就是这个,但是不知道会不会有什么其他隐患,但是这样做确实能满足我的需求
Takamine
2020-09-15 18:56:10 +08:00
@jiobanma 我觉得应该没有问题(因为我也这么干过 2333 ),本质上 mybatis 拦截应该还是看的执行 sql,标签这个只是目前 mybatis 不支持语法的问题。
jiobanma
2020-09-16 09:04:56 +08:00
@Takamine #6 哈哈哈 反正也没有找到其他好的方法 先这么凑合着用吧
Takamine
2020-09-27 22:46:18 +08:00
不过,好像,但是,如果涉及到 mybatis 缓存更新的问题可能有坑,毕竟这里是 select 标签。_(:з」∠)_

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/706754

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX