On Thu, 6 Jan 2022 at 13:13, Avi Weinberg <a...@gilat.com> wrote: > Hi > > > > I have postgres_fdw table called tbl_link. The source table is 2.5 GB in > size with 122 lines (some lines has 70MB bytea column, but not the ones I > select in the example) > > I noticed that when I put the specific ids in the list "where id in > (140,144,148)" it works fast (few ms), but when I put the same list as > select "where id in (select 140 as id union select 144 union select 148)" > it takes 50 seconds. This select union is just for the example, I > obviously have a different select (which by itself takes few ms but cause > the whole insert query to take 10000x more time) > > > > Why is that? How can I still use regular select and still get reasonable > response time? > > > > Thanks > > >
couple of things: PostgreSQL: Documentation: 14: F.35. postgres_fdw <https://www.postgresql.org/docs/current/postgres-fdw.html> <https://www.postgresql.org/docs/current/postgres-fdw.html>when you set your foreign server what are your use_remote_estimate fetch_size params for the foreign server. you need to know there are certain restrictions on what gets pushed down to the remote server i generally use postgres/postgres_fdw.sql at master ยท postgres/postgres (github.com) <https://github.com/postgres/postgres/blob/master/contrib/postgres_fdw/sql/postgres_fdw.sql> as a reference if you predicates are not pushed down, it will bring all the rows from the foreign server to your local server (and fetch_size value and network io will add to delay) and given you used select * , it will be a lot of io, so maybe restrict only to columns needed after being filtered would help. you can try by running explain (verbose,analyze) query and then also enabling log_statement = 'all' / log_min_duration_statement = 0 on the foreign server to see the actual plan for the foreign scan. That might help in trouble shooting. as always, i have little production exposure. If i am wrong, i can be corrected.