dsy19811981 2019-06-21 09:13
浏览 592
已采纳

在插入mysql数据库时获取上次插入ID的最可靠方法是什么

I have found two way to get the last insert id

Result, err := s.DB.ExecContext(ctx, query, qp)
if err != nil {
    return 0, err
}
ID, err := Result.LastInsertId()

and another way is to use mysql's

select LAST_INSERT_ID();

How different are these two methods and what should i do in-case the first method throws an error, would it mean my insert failed or would it mean just that method failed to return the id ?

  • 写回答

1条回答 默认 最新

  • dptpn06684 2019-06-21 09:18
    关注

    Use Result.LastInsertId(). This is always reliable.

    Doing your own SELECT is not reliable, due to the way the Go driver handles pools of connection. If you do, say:

    INSERT foo INTO bar ...
    

    in one statement, then later:

    SELECT LAST_INSERT_ID();
    

    in another statement, you may get different connections to the database for each statement.

    This means your manually-selected ID may correspond with some completely unrelated INSERT statement which just happened to occur on that same connection in the past, or you may get nothing at all.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 救!ENVI5.6深度学习初始化模型报错怎么办?
  • ¥30 eclipse开启服务后,网页无法打开
  • ¥30 雷达辐射源信号参考模型
  • ¥15 html+css+js如何实现这样子的效果?
  • ¥15 STM32单片机自主设计
  • ¥15 如何在node.js中或者java中给wav格式的音频编码成sil格式呢
  • ¥15 不小心不正规的开发公司导致不给我们y码,
  • ¥15 我的代码无法在vc++中运行呀,错误很多
  • ¥50 求一个win系统下运行的可自动抓取arm64架构deb安装包和其依赖包的软件。
  • ¥60 fail to initialize keyboard hotkeys through kernel.0000000000