BUG #18188: wrong varnullingrels

From: PG Bug reporting form <noreply(at)postgresql(dot)org>
To: pgsql-bugs(at)lists(dot)postgresql(dot)org
Cc: fotonszekta(at)gmail(dot)com
Subject: BUG #18188: wrong varnullingrels
Date: 2023-11-09 20:26:41
Message-ID: 18188-2e472071c919b3f1@postgresql.org
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-bugs

The following bug has been logged on the website:

Bug reference: 18188
Logged by: Gábor Szabó
Email address: fotonszekta(at)gmail(dot)com
PostgreSQL version: 16.1
Operating system: windows, ubuntu
Description:

/*
wrong varnullingrels:
Needed a table function call, a LEFT JOIN with that table, and an other join
AFTER the left join.
(The first join must be LEFT, the second join can be any tpye. No data in
tables needed.)

Reproduced on:
Windows 11 + PostgreSQL 16.0, 16.1
Ubuntu 22.04.3 + PostgreSQL 16.1

Tested with no error:
Windows 11 + PostgrSQL 15.4, 15.5,
Ubuntu 22.04.3 + PostgreSQL 12.17, 12.16,
Ubuntu 20.04.6 + PostgreSQL 14.9

Error message from verbose log:

ERROR: XX000: wrong varnullingrels (b) (expected (b 3)) for Var 2/1
LOCATION: search_indexed_tlist_for_var, setrefs.c:2807
STATEMENT: SELECT

table_2.disp,

table_3.table_3_id

FROM table_1

LEFT JOIN table_2 ON table_2.table_2_id = table_1.table_2_id

LEFT JOIN table_3 ON table_3.table_3_id = table_1.table_3_id

script to reproduce:
*/
--
-- PostgreSQL database dump
--

-- Dumped from database version 16.1
-- Dumped by pg_dump version 16.1

SET statement_timeout = 0;
SET lock_timeout = 0;
SET idle_in_transaction_session_timeout = 0;
SET client_encoding = 'UTF8';
SET standard_conforming_strings = on;
SELECT pg_catalog.set_config('search_path', '', false);
SET check_function_bodies = false;
SET xmloption = content;
SET client_min_messages = warning;
SET row_security = off;

--
-- Name: public; Type: SCHEMA; Schema: -; Owner: postgres
--

-- *not* creating schema, since initdb creates it

ALTER SCHEMA public OWNER TO postgres;

SET default_tablespace = '';

SET default_table_access_method = heap;

--
-- Name: table_2; Type: TABLE; Schema: public; Owner: postgres
--

CREATE TABLE public.table_2 (
table_2_id integer NOT NULL
);

ALTER TABLE public.table_2 OWNER TO postgres;

--
-- Name: disp(public.table_2); Type: FUNCTION; Schema: public; Owner:
postgres
--

CREATE FUNCTION public.disp(p_table_2 public.table_2) RETURNS integer
LANGUAGE sql
AS $$

SELECT p_table_2.table_2_id

$$;

ALTER FUNCTION public.disp(p_table_2 public.table_2) OWNER TO postgres;

--
-- Name: table_1; Type: TABLE; Schema: public; Owner: postgres
--

CREATE TABLE public.table_1 (
table_1_id integer NOT NULL,
table_2_id integer,
table_3_id integer
);

ALTER TABLE public.table_1 OWNER TO postgres;

--
-- Name: table_3; Type: TABLE; Schema: public; Owner: postgres
--

CREATE TABLE public.table_3 (
table_3_id integer NOT NULL
);

ALTER TABLE public.table_3 OWNER TO postgres;

--
-- Data for Name: table_1; Type: TABLE DATA; Schema: public; Owner:
postgres
--

COPY public.table_1 (table_1_id, table_2_id, table_3_id) FROM stdin;
\.

--
-- Data for Name: table_2; Type: TABLE DATA; Schema: public; Owner:
postgres
--

COPY public.table_2 (table_2_id) FROM stdin;
\.

--
-- Data for Name: table_3; Type: TABLE DATA; Schema: public; Owner:
postgres
--

COPY public.table_3 (table_3_id) FROM stdin;
\.

--
-- Name: table_1 table_1_pkey; Type: CONSTRAINT; Schema: public; Owner:
postgres
--

ALTER TABLE ONLY public.table_1
ADD CONSTRAINT table_1_pkey PRIMARY KEY (table_1_id);

--
-- Name: table_2 table_2_pkey; Type: CONSTRAINT; Schema: public; Owner:
postgres
--

ALTER TABLE ONLY public.table_2
ADD CONSTRAINT table_2_pkey PRIMARY KEY (table_2_id);

--
-- Name: table_3 table_3_pkey; Type: CONSTRAINT; Schema: public; Owner:
postgres
--

ALTER TABLE ONLY public.table_3
ADD CONSTRAINT table_3_pkey PRIMARY KEY (table_3_id);

--
-- Name: SCHEMA public; Type: ACL; Schema: -; Owner: postgres
--

REVOKE USAGE ON SCHEMA public FROM PUBLIC;
GRANT ALL ON SCHEMA public TO PUBLIC;

--
-- PostgreSQL database dump complete
--

-- restore search_path:
SELECT pg_catalog.set_config('search_path', 'pg_catalog, public', false);

-- query:
SELECT
table_2.disp,
table_3.table_3_id
FROM table_1
LEFT JOIN table_2 ON table_2.table_2_id = table_1.table_2_id
LEFT JOIN table_3 ON table_3.table_3_id = table_1.table_3_id;

Responses

Browse pgsql-bugs by date

  From Date Subject
Next Message Tom Lane 2023-11-09 20:51:01 Re: BUG #18184: ERROR: wrong varnullingrels (b) (expected (b 3)) for Var 2/2
Previous Message Tomas Vondra 2023-11-09 19:14:46 Re: Logical replication is missing block of rows when sending initial sync?