On Thu, Feb 23, 2006 at 12:54:52PM -0600, Kevin Grittner wrote: > >>> On Wed, Feb 22, 2006 at 9:52 pm, in message > <87irr6zq7j.fsf@xxxxxxxxxxxxxxxxx>, Greg Stark <gsstark@xxxxxxx> wrote: > > > > "Kevin Grittner" <Kevin.Grittner@xxxxxxxxxxxx> writes: > > > >> There have been several times that I have run a SELECT COUNT(*) on > an entire > >> table on all central machines. On identical hardware, with identical > data, > >> and equivalent query loads, the PostgreSQL databases have responded > with a > >> count in 50% to 70% of the time of the commercial product, in spite > of the > >> fact that the commercial product does a scan of a non- clustered > index while > >> PostgreSQL scans the data pages. > > > > I take it these are fairly narrow rows? The big benefit of index- > only scans > > come in when you're scanning extremely wide tables, often counting > rows > > matching some indexed criteria. > > I'm not sure what you would consider "fairly narrow rows" -- so see the > attached. This is the VACUUM ANALYZE VERBOSE output for the largest > table, from last night's regular maintenance run. Looks to be about 60 rows per page, somewhere around 140 bytes per row (including overhead). Accounting for overhead and allowing for some empty room, about 100 bytes of data per row, which isn't all that thin. Not all that fat, either... The PK index is about 5 times smaller. IF that ratio holds on the commercial product and they can't beat us with an index scan.... :) -- Jim C. Nasby, Sr. Engineering Consultant jnasby@xxxxxxxxxxxxx Pervasive Software http://pervasive.com work: 512-231-6117 vcard: http://jim.nasby.net/pervasive.vcf cell: 512-569-9461