Re: Constraint exclusion on UNION ALL subqueries with WHERE conditions
В списке pgsql-performance по дате отправления:
| От | Tom Lane |
|---|---|
| Тема | Re: Constraint exclusion on UNION ALL subqueries with WHERE conditions |
| Дата | |
| Msg-id | 25440.1316404770@sss.pgh.pa.us обсуждение |
| Ответ на | Constraint exclusion on UNION ALL subqueries with WHERE conditions (Gunnlaugur Þór Briem <gunnlaugur@gmail.com>) |
| Ответы |
Re: Constraint exclusion on UNION ALL subqueries with WHERE conditions
|
| Список | pgsql-performance |
=?ISO-8859-1?Q?Gunnlaugur_=DE=F3r_Briem?= <gunnlaugur@gmail.com> writes:
> I did this:
> CREATE VIEW unionview AS
> SELECT col, otherstuff FROM (heavy subquery)
> WHERE col BETWEEN 1 AND 3
> UNION ALL
> SELECT col, otherstuff FROM (another heavy subquery)
> WHERE col BETWEEN 4 AND 6;
> hoping that the planner could use the WHERE conditions (like it would use check constraints on tables) to exclude one
ofthe subqueries, for a query like:
> SELECT * FROM unionview WHERE col=2;
> But it doesn't. (In PostgreSQL 8.4.5, at least.)
Works for me in 8.4.8. Do you have constraint_exclusion set to ON?
regards, tom lane
В списке pgsql-performance по дате отправления:
Сайт использует файлы cookie для корректной работы и повышения удобства. Нажимая кнопку «Принять» или продолжая пользоваться сайтом, вы соглашаетесь на их использование в соответствии с Политикой в отношении обработки cookie ООО «ППГ», в том числе на передачу данных из файлов cookie сторонним статистическим и рекламным службам. Вы можете управлять настройками cookie через параметры вашего браузера