On Thu, Jul 11, 2019 at 7:53 AM Peter Geoghegan <p...@bowt.ie> wrote: > Anyway, I think that *hundreds* or even *thousands* of rows are > effectively locked all at once when a bitmap index needs to be updated > in these other systems -- and I mean a heavyweight lock that lasts > until the xact commits or aborts, like a Postgres row lock. As I said, > this is necessary simply because the transaction might need to roll > back. Of course, your patch never needs to do anything like that -- > the only risk is that buffer lock contention will be increased. Maybe > VACUUM isn't so bad after all! > > Doing deduplication adaptively and automatically in nbtree seems like > it might play to the strengths of Postgres, while also ameliorating > its weaknesses. As the same paper goes on to say, it's actually quite > unusual that PostgreSQL has *transactional* full text search built in > (using GIN), and offers transactional, high concurrency spatial > indexing (using GiST). Actually, this is an additional advantages of > our "pure" approach to MVCC -- we can add new high concurrency, > transactional access methods relatively easily.
Good finding, thank you! BTW, I think deduplication could cause some small performance degradation in some particular cases, because page-level locks became more coarse grained once pages hold more tuples. However, this doesn't seem like something we should much care about. Providing an option to turn deduplication off looks enough for me. Regarding bitmap indexes itself, I think our BRIN could provide them. However, it would be useful to have opclass parameters to make them tunable. ------ Alexander Korotkov Postgres Professional: http://www.postgrespro.com The Russian Postgres Company