Re: Out of memory error when doing an update with IN clause

Поиск
Список
Период
Сортировка
От Tom Lane
Тема Re: Out of memory error when doing an update with IN clause
Дата
Msg-id 19159.1072744431@sss.pgh.pa.us
обсуждение исходный текст
Ответ на Re: Out of memory error when doing an update with IN clause  (Sean Shanny <shannyconsulting@earthlink.net>)
Ответы Re: Out of memory error when doing an update with IN clause
Список pgsql-general
Sean Shanny <shannyconsulting@earthlink.net> writes:
> I run this:

> explain update f_commerce_impressions set servlet_key = 60 where
> servlet_key in (68,69,70,71,87,90,94,91,98,105,106);
> ERROR:  out of memory
> DETAIL:  Failed on request of size 1024.

Well, I have to confess to total bafflement.  AFAICS the overflowing
hash table must be the duplicate-tuple hash table that nodeIndexscan.c
sets up --- but that table shouldn't get any entries loaded into it
if you just do EXPLAIN with no ANALYZE.  Furthermore, it should only
get loaded with entries for tuples that match the WHERE clause, and
you said earlier that there are no rows with these servlet_key values.
The code involved is all new in 7.4, so finding a bug in it wouldn't
surprise me much, but I can't see how this could be happening.

It would help if you could rebuild with --enable-debug (if that wasn't
on already) and get a stack trace from the errfinish() call.  Or, is
there any chance I could get access to your machine and look at the
problem for myself?

            regards, tom lane

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

Предыдущее
От: "Gavin M. Roy"
Дата:
Сообщение: PG_Autotune
Следующее
От: "Grant Allen"
Дата:
Сообщение: Any way to disable backslash as a string literal escape character?