Re: Updating a specific number of rows in pl/pgsql
От | Pavel Stehule |
---|---|
Тема | Re: Updating a specific number of rows in pl/pgsql |
Дата | |
Msg-id | 162867790908110355g3b62cc56u1c74092dd01bbd8e@mail.gmail.com обсуждение исходный текст |
Ответ на | Re: Updating a specific number of rows in pl/pgsql ("D'Arcy J.M. Cain" <darcy@druid.net>) |
Ответы |
Re: Updating a specific number of rows in pl/pgsql
|
Список | pgsql-sql |
2009/8/11 D'Arcy J.M. Cain <darcy@druid.net>: > On Mon, 10 Aug 2009 17:52:36 -0700 > "Peter Headland" <pheadland@actuate.com> wrote: >> I can get the rows I want to update like this: >> >> SELECT * >> FROM queue >> WHERE id = p_queue_id >> ORDER BY rank >> LIMIT p_number_of_items; >> >> Of course, there may not be p_number_of_items available in the queue. >> >> I want to update all the rows in the cursor in the same way: >> >> UPDATE queue SET assigned = TRUE; > > Assuming that there is a unique identifier on queue, let's call it > queue_id, you should be able to do something like this: > > UPDATE queue SET assigned = TRUE > WHERE queue_id IN (SELECT queue_id > FROM queue > WHERE id = p_queue_id > ORDER BY rank > LIMIT p_number_of_items); > there are one fast trick http://www.postgres.cz/index.php/PostgreSQL_SQL_Tricks#Fast_first_n_rows_removing p.s. replace DELETE by UPDATE regards Pavel Stehule > -- > D'Arcy J.M. Cain <darcy@druid.net> | Democracy is three wolves > http://www.druid.net/darcy/ | and a sheep voting on > +1 416 425 1212 (DoD#0082) (eNTP) | what's for dinner. > > -- > Sent via pgsql-sql mailing list (pgsql-sql@postgresql.org) > To make changes to your subscription: > http://www.postgresql.org/mailpref/pgsql-sql >
В списке pgsql-sql по дате отправления: