Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> JOIN na fragmencie
soomal
post
Post #1





Grupa: Zarejestrowani
Postów: 38
Pomógł: 1
Dołączył: 4.03.2007

Ostrzeżenie: (0%)
-----


Wybieranie filmów podobnych na podstawie przypisanych im tagów.

tabela filmy:
film_id,adres,nazwa

tabela tag_film
film_id,tag_id

  1. SELECT DISTINCT filmy.film_id AS film_id,adres,nazwa
  2. FROM filmy INNER JOIN tag_film USING (film_id) WHERE tag_id IN (SELECT tag_id FROM tag_film WHERE film_id='.$film_id.')


Działa. Problem jest taki, że działa bardzo wolno.
Prawdopodobna przyczyna: Najpierw wykonywany jest join na całej tabeli, dopiero później wybiera się z niej fragment z film_id równy podanemu w zmiennej.

Jak można zoptymalizować to zapytanie?

Ten post edytował soomal 16.09.2007, 19:10:06
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
soomal
post
Post #2





Grupa: Zarejestrowani
Postów: 38
Pomógł: 1
Dołączył: 4.03.2007

Ostrzeżenie: (0%)
-----


  1. 1 PRIMARY tag_film ALL
  2. 1 PRIMARY filmy eq_ref PRIMARY PRIMARY 4 soomal_baza.tag_film.film_id 1
  3. 2 DEPENDENT SUBQUERY tag_film ALL


Coś takiego dało EXPLAIN.

Cytat
WHERE tag_id IN (SELECT tag_id FROM tag_film WHERE film_id='.$film_id.') nie łatwiej where film_id='.$film_id.'


where film_id=.'$film_id.' miało by zastąpić cały ten fragment? Nie sądziłem, że to tak może zadziałać.
Go to the top of the page
+Quote Post

Posty w temacie


Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 9.10.2025 - 16:09