Re: count * performance issue

Поиск
Список
Период
Сортировка
От Craig James
Тема Re: count * performance issue
Дата
Msg-id 47D0AFC1.5070305@emolecules.com
обсуждение исходный текст
Ответ на Re: count * performance issue  (Tom Lane <tgl@sss.pgh.pa.us>)
Ответы Re: count * performance issue
Re: count * performance issue
Benchmark: Dell/Perc 6, 8 disk RAID 10
Список pgsql-performance
Tom Lane wrote:
> Craig James <craig_james@emolecules.com> writes:
>> Count() on Oracle and MySQL is almost instantaneous, even for very large tables. So why can't Postgres do what they
do?
>
> AFAIK the above claim is false for Oracle.  They have the same
> transactional issues we do.

My experience doesn't match this claim.  When I ported my application from Oracle to Postgres, this was the single
biggestperformance problem.  count() in Oracle was always very fast.  We're not talking about a 20% or 50% difference,
we'retalking about a small fraction of a second (Oracle) versus a minute (Postgres) -- something like two or three
ordersof magnitude. 

It may be that Oracle has a way to detect when there's no transaction and use a faster method.  If so, this was a
cleveroptimization -- in my experience, that represents the vast majority of the times you want to use count().  It's
notvery useful to count the rows of a table that many apps are actively modifying since the result may change the
momentyour transaction completes.  Most of the time when you use count(), it's because you're the only one modifying
thetable, so the count will be meaningful. 

Craig


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

Предыдущее
От: Mark Kirkwood
Дата:
Сообщение: Re: count * performance issue
Следующее
От: "b wragg"
Дата:
Сообщение: Improve Full text rank in a query