How to optimize query or just force postgre to do it my way ?

Example:
  table continets (
    id numeric, ..., active numeric
  );

  table countries (
    id numeric, id_continent numeric, ..., active numeric
  );

  table cities (
    id numeric, id_country numeric, ..., active numeric
  );

relations:
  cities.id_county are in countries.id
  countries.id_continent are on continents.id

Query:
  table temp_cities (
    id_city numeric;
  );


temp_cities is temp table which holds few (~20) id of cities, to
show them.

so:
  select * from cities 
    where cities.id in (select id_city from temp_cities);
or:
  select * from cities, temp_cities tmp
    where cities.id = tmp.id_city;
works fine.

But the problem starts here:

  select * from cities, coutries, continets
    where 
      (cities.id in (select id_city from temp_cities)) and
      (cities.id_county = countries.id) and
      (countries.id_continent = continents.id) and
      (cities.active = 1) and (coutries.active = 1) and
      (continents.active = 1)

(active means is row active or archive, many of them are active,
but I have to check it)

Posgre is planning it like this:
  joins cities with coutries
  joins countries with continents
  selects active
  filtering with cities.id (with temp_cities)

If I could force it to filter cities.id first 
(I can do this with Oracle by changing 
"select id_city from temp_cities" to 
"select id_city from temp_cities group by id_city")
it will work much (1000x) faster.

Can I force postgre do it my way ?
-- 
[ Milosz "Krashan" Krajewski ][ mail: [EMAIL PROTECTED], UIN: 1319535 ]
[ inet: Vilge, Vilgefortz    ][ www: http://www.ds2.pg.gda.pl/~krash ]

---------------------------(end of broadcast)---------------------------
TIP 2: you can get off all lists at once with the unregister command
    (send "unregister YourEmailAddressHere" to [EMAIL PROTECTED])

Reply via email to