sql - 如何创建一个插入但随后返回插入数据的事务

标签 sql postgresql go sqlx

我正在开发 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
}

关于sql - 如何创建一个插入但随后返回插入数据的事务,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51779014/

相关文章:

sql - "Coalesce"多列

golang windows服务失败,没有任何错误

mysql - postgres 和 mysql 上的通用大写搜索不起作用

mysql - SQL 选择名字但不包含姓氏匹配

sql - 分组总和()按灵活间隔分区

javascript - 如何使用 Nodejs 将 SQLite 索引放入变量中?

ruby-on-rails - Rails PostgreSQL:列 "table_rows"不存在(ActiveRecord::StatementInvalid)

sockets - 在 GO 中通过原始套接字读取 TCP 数据包

windows - 如何使用 Go 翻转文件的 Windows 存档位

java - 如何定期更新 xml 文件?