如何创建要插入但随后返回插入数据的事务

时间:2018-08-10 04:33:51

标签: sql postgresql go sqlx

我正在使用REST API,因此我正在尝试为用户提供一种创建新服务凭单的方法。

除了将内容存储在db(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 {
    ////
}

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

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

1 个答案:

答案 0 :(得分:1)

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
}