On 11/03 12:58:37, Laurenz Albe wrote:
> On Tue, 2025-03-11 at 19:45 +1100, Peter Wright wrote:
> > PostgreSQL version: 17.4
> > Operating system: Ubuntu 24.04, x86_64, kernel 6.8.0-51-generic
> > Description:
> >
> > Given a file "break_it.sql" containing this SQL:
> >
> > SELECT version();
> > CREATE VIEW things AS SELECT 1 AS id, 'rock' AS thing_name;
> > CREATE FUNCTION num_things() RETURNS INTEGER AS $$ SELECT COUNT(1) FROM things; $$ LANGUAGE SQL STABLE;
> > CREATE MATERIALIZED VIEW thing_report AS SELECT num_things() AS number_of_things;
> >
> > Running the following commands with the environment pointing at a PostgreSQL 17.4 server:
> >
> > psql:break_it.sql:4: ERROR: relation "things" does not exist
> > LINE 1: SELECT COUNT(1) FROM things;
> > ^
> > QUERY: SELECT COUNT(1) FROM things;
> > CONTEXT: SQL function "num_things" during inlining
> >
> >
> > Running the same commands with the environment pointing at a PostgreSQL 16.8
> > server does *not* report an error
>
> That is not a bug, it is intentional.
> See the first entry in the list of incompatibilities
> https://www.postgresql.org/docs/current/release-17.html#RELEASE-17-MIGRATION
Aha! Noted, and thank you.
I spent some time looking for evidence that this was an intentional
change, but apparently didn't look in the most obvious place. <facepalm>
It also seemed counter-intuitive that CREATE MATERIALIZED VIEW would
use a different search path to CREATE VIEW - but makes sense now I know
that materialized view create/refresh are “maintenance operations”.
> You should fix the function.
I will. :-)
> Yours,
> Laurenz Albe
Pete.
--
If at first you don't succeed, you must be a programmer.