From: | Torsten Förtsch <torsten(dot)foertsch(at)gmx(dot)net> |
---|---|
To: | Jean-Max Reymond <jmreymond(at)free(dot)fr>, pgsql-performance(at)postgresql(dot)org |
Subject: | Re: Performance of UNION vs IN |
Date: | 2014-03-20 17:13:58 |
Message-ID: | 532B21D6.2030309@gmx.net |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-performance |
On 20/03/14 17:57, Jean-Max Reymond wrote:
> I have a very complex view zinfoexp and running the view as:
> SELECT * FROM zinfoexp WHERE idmembre in (1,84)
> take 2700 ms
>
> So, I try another syntax:
> SELECT * FROM zinfoexp WHERE idmembre = 1
> union
> SELECT * FROM zinfoexp WHERE idmembre = 84
>
> and for me, two calls to my view takes a lot of time (may be x2) and it
> takes 134 ms !
try
SELECT * FROM zinfoexp WHERE idmembre=1 OR idmembre=84
This will probably be even faster.
Also, the 2 statements of your's are not semantically equal. UNION
implies DISTINCT, see:
select * from (values (1), (1), (2)) t(i) UNION select 19;
i
----
19
1
2
(3 rows)
What you want is UNION ALL:
select * from (values (1), (1), (2)) t(i) UNION ALL select 19;
i
----
1
1
2
19
(4 rows)
Torsten
From | Date | Subject | |
---|---|---|---|
Next Message | Stefan Amshey | 2014-03-20 23:56:03 | slow join not using index properly |
Previous Message | Tom Lane | 2014-03-20 17:08:50 | Re: Getting query plan alternatives from query planner? |