登录
首页 >  Golang >  Go问答

如何创建一个插入然后返回插入数据的事务

来源:stackoverflow

时间:2024-04-16 21:36:33 382浏览 收藏

大家好,今天本人给大家带来文章《如何创建一个插入然后返回插入数据的事务》,文中内容主要涉及到,如果你对Golang方面的知识点感兴趣,那就请各位朋友继续看下去吧~希望能真正帮到你们,谢谢!

问题内容

我正在开发 rest api,因此我尝试实现一种让用户创建新服务票证的方法。

一切工作正常,除了在数据库(postgres)中存储内容时除外。

以下是交易生成后的片段:

begin;

insert into service_request (id, ...)
values (...);

insert into media (id, filename, ...)
values (...),
(...),
(...);

insert into servicerequest_media(service_request_id, media_id)
values (..., ...),
(..., ...),
(...,...);

commit;

使用sqlx准备好的语句,我知道结果包含一些元数据,例如最后插入的id。但是,如何将 select 查询添加到我的事务中并获取该查询的结果?

stmt, err := s.db.Prepare(CREATE_SERVICE_REQUEST)
if err != nil {
    //// 
}
res, err := stmt.Exec()
if err != nil {
    ////
}

或者,我需要进行第二次查询才能获得结果吗?

我对此还很陌生,所以如果我需要提供更多背景信息,请告诉我。


解决方案


Exec 不返回创建或插入的行。它只返回最后插入的元素id。

如果您想获取行,可以考虑使用 QueryQueryRow

rows, err := stmt.Query()
if rows.Next {
    // declare variable of any type string, int or struct
    rows.Scan(&variable) // string, int
    // or
    rows.Scan(&variable.field1, &variable.field2) // where field1, field2 are the properties of your struct
    // do whatever you want with the variable
}

理论要掌握,实操不能落!以上关于《如何创建一个插入然后返回插入数据的事务》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>