Re: Counting records in a PL/pgsql cursor

Поиск
Список
Период
Сортировка
От Magnus Hagander
Тема Re: Counting records in a PL/pgsql cursor
Дата
Msg-id 6BCB9D8A16AC4241919521715F4D8BCEA358A1@algol.sollentuna.se
обсуждение исходный текст
Ответ на Re: Counting records in a PL/pgsql cursor  ("redhog" <redhog@redhog.org>)
Список pgsql-general
> > Nope, the query is way too expensive to run it twice. (GIN
> scan over
> > well over half a million rows. It's faster to do the
> > get-as-cursor-then-loop-and-increment, I've measured that)
>
> Can't you select into a temporary table and then do select
> count(*) over that table, aswell as run your cursor over that
> temporary table?
> Or is that way to space expensive?

I could, but just looping through the resultset is cheaper than that -
everything sticks in memory. The actual resultset isn't thatbig (max
1,000 rows), so there is no real risk to run out of memory for it inside
the functino.

//Magnus

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

Предыдущее
От: "redhog"
Дата:
Сообщение: Re: Counting records in a PL/pgsql cursor
Следующее
От: "A. Kretschmer"
Дата:
Сообщение: Re: problem accessing a database