On Tue, 2006-08-08 at 12:49, Patrice Beliveau wrote:
> Hi,
> 
> I have a query that use a function and some column test to select row. 
> It's in the form of:
> 
> SELECT * FROM TABLE
>    WHERE TABLE.COLUMN1=something
>       AND TABLE.COLUMN2=somethingelse
>       AND function(TABLE.COLUMN3,TABLE.COLUMN4) > 0;
> 
> The result of the function does NOT depend only from the table, but also 
> from some other tables.
> 
> Since it's long to process, I've add some output to see what's going on. 
> I find out that the function process every row even if the row should be 
> rejected as per the first or the second condition. Then , my question 
> is: Is there a way to formulate a query that wont do all the check if it 
> does not need to do it ? Meaning that, if condition1 is false then it 
> wont check condition2 and that way the function will only be called when 
> it's really necessary.

What version of postgresql are you running?  It might be better in later
versions.  The standard fix for such things is to use a subquery...

select * from (
   select * from table where 
   col1='something'
   and col2='somethingelse'
) as a
where function(a.col3,a.col4) > 0;

---------------------------(end of broadcast)---------------------------
TIP 3: Have you checked our extensive FAQ?

               http://www.postgresql.org/docs/faq

Reply via email to