Re: Optimizing queries

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



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;


[Postgresql General]     [Postgresql PHP]     [PHP Users]     [PHP Home]     [PHP on Windows]     [Kernel Newbies]     [PHP Classes]     [PHP Books]     [PHP Databases]     [Yosemite]

  Powered by Linux