"internal error" triggered by EXISTS()

Поиск
Список
Период
Сортировка
От Tom Lane
Тема "internal error" triggered by EXISTS()
Дата
Msg-id 17025.900451896@sss.pgh.pa.us
обсуждение исходный текст
Ответы Re: [HACKERS] "internal error" triggered by EXISTS()  (dg@illustra.com (David Gould))
Re: [HACKERS] "internal error" triggered by EXISTS()  (Bruce Momjian <maillist@candle.pha.pa.us>)
Список pgsql-hackers
I tried the following to find out whether a table has any records
with field1 < X (for a constant X):

tgl=> SELECT EXISTS(SELECT * FROM table WHERE field1 < X);
ERROR:  internal error: do not know how to transform targetlist

Is this a bug?  (I'm using development sources from yesterday.)

Am I using EXISTS() incorrectly?  The examples I've been able to find
only show it as a part of a WHERE clause.

If it did work, would it be any faster than a table scan?  The code
I was hoping to replace is like this:
    SELECT COUNT(field1) WHERE field1 < X;
    // test whether result > 0
Since aggregates aren't optimized very well, this ends up reading
much or all of the table, even if there is an index for field1.
I was hoping EXISTS() might be smarter...

            regards, tom lane

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

Предыдущее
От: Mike Embry
Дата:
Сообщение: SEQUENCES and COPY FROM
Следующее
От: dg@illustra.com (David Gould)
Дата:
Сообщение: Re: [HACKERS] "internal error" triggered by EXISTS()