Re: index prefetching - Mailing list pgsql-hackers
From | Tomas Vondra |
---|---|
Subject | Re: index prefetching |
Date | |
Msg-id | 2da36b28-4720-4178-b569-153790dd694e@enterprisedb.com Whole thread Raw |
In response to | Re: index prefetching (Konstantin Knizhnik <knizhnik@garret.ru>) |
Responses |
Re: index prefetching
|
List | pgsql-hackers |
On 1/19/24 16:19, Konstantin Knizhnik wrote: > > On 18/01/2024 5:57 pm, Tomas Vondra wrote: >> On 1/16/24 21:10, Konstantin Knizhnik wrote: >>> ... >>> >>>> 4. I think that performing prefetch at executor level is really great >>>>> idea and so prefetch can be used by all indexes, including custom >>>>> indexes. But prefetch will be efficient only if index can provide fast >>>>> access to next TID (located at the same page). I am not sure that >>>>> it is >>>>> true for all builtin indexes (GIN, GIST, BRIN,...) and especially for >>>>> custom AM. I wonder if we should extend AM API to make index make a >>>>> decision weather to perform prefetch of TIDs or not. >>>> I'm not against having a flag to enable/disable prefetching, but the >>>> question is whether doing prefetching for such indexes can be harmful. >>>> I'm not sure about that. >>> I tend to agree with you - it is hard to imagine index implementation >>> which doesn't win from prefetching heap pages. >>> May be only the filtering case you have mentioned. But it seems to me >>> that current B-Tree index scan (not IOS) implementation in Postgres >>> doesn't try to use index tuple to check extra condition - it will fetch >>> heap tuple in any case. >>> >> That's true, but that's why I started working on this: >> >> https://commitfest.postgresql.org/46/4352/ >> >> I need to think about how to combine that with the prefetching. The good >> thing is that both changes require fetching TIDs, not slots. I think the >> condition can be simply added to the prefetch callback. >> >> >> regards >> > Looks like I was not true, even if it is not index-only scan but index > condition involves only index attributes, then heap is not accessed > until we find tuple satisfying search condition. > Inclusive index case described above > (https://commitfest.postgresql.org/46/4352/) is interesting but IMHO > exotic case. If keys are actually used in search, then why not to create > normal compound index instead? > Not sure I follow ... Firstly, I'm not convinced the example addressed by that other patch is that exotic. IMHO it's quite possible it's actually quite common, but the users do no realize the possible gains. Also, there are reasons to not want very wide indexes - it has overhead associated with maintenance, disk space, etc. I think it's perfectly rational to design indexes in a way eliminates most heap fetches necessary to evaluate conditions, but does not guarantee IOS (so the last heap fetch is still needed). What do you mean by "create normal compound index"? The patch addresses a limitation that not every condition can be translated into a proper scan key. Even if we improve this, there will always be such conditions. The the IOS can evaluate them on index tuple, the regular index scan can't do that (currently). Can you share an example demonstrating the alternative approach? regards -- Tomas Vondra EnterpriseDB: http://www.enterprisedb.com The Enterprise PostgreSQL Company
pgsql-hackers by date: