Re: Security barrier view index on join condition - Mailing list pgsql-bugs

From Tom Lane
Subject Re: Security barrier view index on join condition
Date
Msg-id 1541999.1715357417@sss.pgh.pa.us
Whole thread Raw
In response to Security barrier view index on join condition  (Jacques Combrink <jacques@quantsolutions.co.za>)
List pgsql-bugs
Jacques Combrink <jacques@quantsolutions.co.za> writes:
> I have the following situation where I don't understand why the underlying
> index will not be used through the security_barrier view.

[ shrug ... ]  A security barrier is a pretty crippling restriction
on what the optimizer can do.  The barrier view will always be planned
separately, which is why you usually end up with a seqscan on join_test_2.

> Although when I change the query WHERE condition to a straight up equals,
> it somehow works:

> EXPLAIN ANALYZE
> SELECT l2_security_view.id FROM join_test
> LEFT JOIN l2_security_view USING(id)
> WHERE join_test.id = 6;

This happens to work because the implied USING qual is combined with
the equality clause from WHERE to produce the replacement conditions
"join_test.id = 6 AND l2_security_view.id = 6".  Then, after verifying
that the subquery's restriction clause "l2_security_view.id = 6" is
leakproof, it's allowed to be pushed down into the subquery, becoming
"join_test_2.id = 6", from which the subquery can produce an indexscan
plan.  But that doesn't work for normal join conditions, since those
can't be pushed into the subquery.  It also doesn't get applied with
WHERE conditions that are anything but simple equality to a constant.

Certainly there's work that could be done to make this a little
better, but it would be a lot of work and probably would not move the
goalposts very far.  You should expect security barriers to hurt
performance-wise.

            regards, tom lane



pgsql-bugs by date:

Previous
From: Jacques Combrink
Date:
Subject: Security barrier view index on join condition
Next
From: Sandeep Thakkar
Date:
Subject: Re: Postgresql 16.3 installation error (setup file) on Windows 11