我无法通过 PostgreSQL 文档、网络甚至 StackOverflow 获得有关这个简单问题的信息……我一定不明白这里的一些重要内容。
我正在做一个简单的SELECT
/UPDATE
PostgreSQL 中的事务:
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
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)