看到网上是这么写的
<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
1
chihiro2014 2020-09-14 09:57:48 +08:00
用 JPA 就可以摆脱 XML 地狱了
|
2
ourslay 2020-09-14 10:19:05 +08:00 via iPhone
试试 spring data jdbc
|
3
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()); } } |
4
Takamine 2020-09-14 17:59:26 +08:00 via Android
……可以试试一个黑魔法,把<insert>标签改成<select>标签使用 pg 的 returning 来做。
|
5
jiobanma OP @Takamine #4 我在网上也找到这个黑魔法了,现在用的就是这个,但是不知道会不会有什么其他隐患,但是这样做确实能满足我的需求
|
6
Takamine 2020-09-15 18:56:10 +08:00 via Android
@jiobanma 我觉得应该没有问题(因为我也这么干过 2333 ),本质上 mybatis 拦截应该还是看的执行 sql,标签这个只是目前 mybatis 不支持语法的问题。
|
8
Takamine 2020-09-27 22:46:18 +08:00 via Android
不过,好像,但是,如果涉及到 mybatis 缓存更新的问题可能有坑,毕竟这里是 select 标签。_(:з」∠)_
|