Re: Security barrier view index on join condition

From: Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>
To: Jacques Combrink <jacques(at)quantsolutions(dot)co(dot)za>
Cc: pgsql-bugs(at)lists(dot)postgresql(dot)org
Subject: Re: Security barrier view index on join condition
Date: 2024-05-10 16:10:17
Message-ID: 1541999.1715357417@sss.pgh.pa.us
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-bugs

Jacques Combrink <jacques(at)quantsolutions(dot)co(dot)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

In response to

Browse pgsql-bugs by date

  From Date Subject
Next Message Sandeep Thakkar 2024-05-13 02:34:02 Re: Postgresql 16.3 installation error (setup file) on Windows 11
Previous Message Jacques Combrink 2024-05-10 15:40:02 Security barrier view index on join condition