Re: [GENERAL] Retrieving query results

Поиск
Список
Период
Сортировка
От Tom Lane
Тема Re: [GENERAL] Retrieving query results
Дата
Msg-id 32584.1503579096@sss.pgh.pa.us
обсуждение исходный текст
Ответы Re: [GENERAL] Retrieving query results
Список pgsql-general
Michael Paquier <michael.paquier@gmail.com> writes:
> On Wed, Aug 23, 2017 at 3:19 AM, Igor Korot <ikorot01@gmail.com> wrote:
>> [quote]
>> PQntuples
>>
>> Returns the number of rows (tuples) in the query result. Because it
>> returns an integer result, large result sets might overflow the return
>> value on 32-bit operating systems.
>>
>> int PQntuples(const PGresult *res);
>> [/quote]
>>
>> Is there another way to not to overflow the result?

> Not really with the existing API.

Actually, that documentation note is pretty beside-the-point, if not
outright wrong.  The real issue here is that libpq's internal row counter
is also a plain int.  As are the rownumber arguments to PQgetvalue and so
on.  While we could widen that internal counter, it's useless to do so
as long as these API choices prevent applications from dealing with
resultsets of more than 2G rows.

I think what we need is to (1) introduce some error checking in libpq so
that it reports an error if the resultset exceeds 2G rows --- right now
it'll just crash, I fear, and (2) change the documentation so that this
is explained as a library-wide limitation and not just a problem with
PQntuples.

            regards, tom lane


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

Предыдущее
От: Tom Lane
Дата:
Сообщение: Re: [GENERAL] Explain analyse and toasted data.
Следующее
От: Igor Korot
Дата:
Сообщение: Re: [GENERAL] Retrieving query results