繁体   English   中英

如何在事务中获取SELECT语句的结果?

[英]How to get the result of SELECT statement inside a transaction?

我无法通过 PostgreSQL 文档、Web 甚至 StackOverflow 上的这个简单问题获得信息......我一定不明白这里的一些重要内容。

我正在 PostgreSQL 中做一个简单的SELECT / UPDATE事务:

START TRANSACTION;
SELECT "column" FROM "table" WHERE "criterion" = 'value' AND "activated" = true;
UPDATE "table" SET "activated" = false WHERE "criterion" = 'value';
COMMIT

基本上,我需要在activated状态为true时获取列的值,然后将其停用。 PostgreSQL 告诉我有 1 行结果已被取消

如果我执行以下操作(基本上是没有UPDATE语句的相同事务),也会发生同样的情况:

START TRANSACTION;
SELECT "column" FROM "table" WHERE "criterion" = 'value' AND "activated" = true;
COMMIT

我对交易有什么不了解? 任何SELECT输出都不能从事务块中取出吗?

这将从更新的行中返回所有“列”的值:

UPDATE "table" SET "activated" = false WHERE "criterion" = 'value' AND "activated" = true
returning "column";

与交易无关。

returning将返回值,就像发出select

insert into foo (ticket, row, archived) values (3,7,true) returning *;
 ticket | row | archived 
--------+-----+----------
      3 |   7 | t

update foo
set archived = true
where not archived
returning *;
 ticket | row | archived 
--------+-----+----------
      2 |   5 | t

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM