V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
jiobanma
V2EX  ›  Java

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

  •  
  •   jiobanma ·
    banmajio · 2020-09-14 09:46:18 +08:00 · 1882 次点击
    这是一个创建于 1292 天前的主题,其中的信息可能已经有所发展或是发生改变。

    看到网上是这么写的

    <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

    8 条回复    2020-09-27 22:46:18 +08:00
    chihiro2014
        1
    chihiro2014  
       2020-09-14 09:57:48 +08:00
    用 JPA 就可以摆脱 XML 地狱了
    ourslay
        2
    ourslay  
       2020-09-14 10:19:05 +08:00 via iPhone
    试试 spring data jdbc
    yongle1117
        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());
    }

    }
    Takamine
        4
    Takamine  
       2020-09-14 17:59:26 +08:00 via Android
    ……可以试试一个黑魔法,把<insert>标签改成<select>标签使用 pg 的 returning 来做。
    jiobanma
        5
    jiobanma  
    OP
       2020-09-15 09:11:40 +08:00
    @Takamine #4 我在网上也找到这个黑魔法了,现在用的就是这个,但是不知道会不会有什么其他隐患,但是这样做确实能满足我的需求
    Takamine
        6
    Takamine  
       2020-09-15 18:56:10 +08:00 via Android
    @jiobanma 我觉得应该没有问题(因为我也这么干过 2333 ),本质上 mybatis 拦截应该还是看的执行 sql,标签这个只是目前 mybatis 不支持语法的问题。
    jiobanma
        7
    jiobanma  
    OP
       2020-09-16 09:04:56 +08:00
    @Takamine #6 哈哈哈 反正也没有找到其他好的方法 先这么凑合着用吧
    Takamine
        8
    Takamine  
       2020-09-27 22:46:18 +08:00 via Android
    不过,好像,但是,如果涉及到 mybatis 缓存更新的问题可能有坑,毕竟这里是 select 标签。_(:з」∠)_
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   5404 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 38ms · UTC 08:58 · PVG 16:58 · LAX 01:58 · JFK 04:58
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.