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 по дате отправления:

Предыдущее
От: "D'Arcy J.M. Cain"
Дата:
Сообщение: Re: Updating a specific number of rows in pl/pgsql
Следующее
От: Jasen Betts
Дата:
Сообщение: Re: Determining logically unique entities across many partially complete rows where at least one column matches