Help on update.

Поиск
Список
Период
Сортировка
От paulo matadr
Тема Help on update.
Дата
Msg-id 143637.77662.qm@web52506.mail.re2.yahoo.com
обсуждение исходный текст
Ответы Re: Help on update.  (Kenichiro Tanaka <ketanaka@ashisuto.co.jp>)
Re: Help on update.  (Jayadevan M <Jayadevan.Maymala@ibsplc.com>)
Список pgsql-general

create table test(i number , j number);
insert into test values(1,2)
insert into test values(1,3)
insert into test values(1,4)

select * from test;
I J
---------- ----------
1 2
1 3
1 4

My  intentions:
after update
select * from test;
I J
---------- ----------
1 2
1 3+2
1 4+3
after
select * from test;
I J
---------- ----------
1 2
1 5+2
1 7+5

In oracle,I use this:
update test x
set x.j = x.j + (select lag_j
from (select i, j, nvl(lag(j) over (order by i,j) ,0) as lag_j
from test) y
where x.i = y.i and x.j = y.j)

how can translate this for work in postgres?

Thanks's

Paul









Paulo


 

В списке pgsql-general по дате отправления:

Предыдущее
От: Or Kroyzer
Дата:
Сообщение: recovery after interrupt in the middle of a previous recovery
Следующее
От: Tom Lane
Дата:
Сообщение: Re: recovery after interrupt in the middle of a previous recovery