Re: PQdeleteTuple function in libpq

Поиск
Список
Период
Сортировка
От Andrew Chernow
Тема Re: PQdeleteTuple function in libpq
Дата
Msg-id 4DE7B660.8040704@esilo.com
обсуждение исходный текст
Ответ на Re: PQdeleteTuple function in libpq  (Alvaro Herrera <alvherre@commandprompt.com>)
Ответы Re: PQdeleteTuple function in libpq  (Pavel Golub <pavel@microolap.com>)
Список pgsql-hackers
On 6/2/2011 11:02 AM, Alvaro Herrera wrote:
> Excerpts from Andrew Chernow's message of jue jun 02 10:12:40 -0400 2011:
>
>>> Andrew, why we have PQmakeEmptyPGresult, PQcopyResult,
>>> PQsetResultAttrs, PQsetvalue and PQresultAlloc in this case? Of course
>>> there's no big deal with their absence but let's be consistent.
>>
>> I'm not entirely sure what you are trying to do, but can't you use
>> PQmakeEmptyPGresult, PQsetResultAttrs and PQsetvalue to construct a
>> result that excludes the tuples you don't want followed by a
>> PQclear(initial_result)?
>
> Seems pretty wasteful if you want to delete a single tuple from a large
> result.  I think if you desired to compact the result to free some
> memory after deleting a large fraction of the tuples in the result it
> could be useful to do that, otherwise just live with the unused holes in
> the storage area as suggested by Pavel.
>

Another solution is to manually cursor through the set (like grab 1000 
tuples at a time) and copy the set to your own structure.  That way, the 
temporary double memory to perform the copy is not as big of a hit.  By 
using your own structure, you can organize the memory in a fashion that 
is optimized for your requirement.

-- 
Andrew Chernow
eSilo, LLC
global backup
http://www.esilo.com/


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

Предыдущее
От: Andrew Dunstan
Дата:
Сообщение: Re: Please test peer (socket ident) auth on *BSD
Следующее
От: Tom Lane
Дата:
Сообщение: Re: Please test peer (socket ident) auth on *BSD