如何创建插入但随后 returns 插入数据的事务
How to create a transaction that inserts but then returns the inserted data
我正在研究 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 不会 return 创建或插入的行。它只是 return 最后插入的元素 ID。
如果想获取行数,可以考虑使用Query or QueryRow。
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
}
我正在研究 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 不会 return 创建或插入的行。它只是 return 最后插入的元素 ID。
如果想获取行数,可以考虑使用Query or QueryRow。
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
}