如何在 Postgresql 事务内部将值获取到变量中,如果 SELECT 没有返回任何内容,则抛出错误,如果 SELECT 返回数据,则在事务中使用它们?
像这样:
BEGIN;
@activeRounds = SELECT * FROM "rounds" WHERE status = 'active';
if(!@activeRounds) {
RAISE ERROR "Has no Active rounds"
};
INSERT INTO "bet"
(user_id, round_id)
VALUES
(100, @activeRound[0].id)
COMMIT;
如何在一笔交易的一个请求中做类似的事情?
您可以根据您的表结构调整以下代码:
begin;
do
$$
declare
v int;
begin
select c1 into v from t1 where k1=1;
if not found
then
raise exception 'no row found';
else
insert into t2(c2) values(v);
end if;
end;
$$;
commit;
注意之间的区别begin;
开始交易并begin
启动 pl/pgSQL 块。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)