2016-05-03 3 views
1

Ich habe drei Tabellen: Filme, Schauspieler und die Beziehung actioners_film.Anzahl der ID in Relation und Verbindung zum Namen in PostgreSQL

Ich versuche zu entscheiden, welche Schauspieler in den meisten Filmen gewesen ist. Wenn der Schauspieler in einem Film war, wird dies mit actor_id (Primärschlüssel) angezeigt.

Ich dachte, ich die Anzahl der jeweils actor_id zeigt in der Tabelle film_actor für jeden film_id, und dann verbinden dies mit dem richtigen Namen (actor.first_name) zählen möchten.

Ich habe den ersten Teil unten, aber kann nicht scheinen, den Count-Wert mit dem richtigen Namen zu verbinden.

Wie würde ich fortfahren, den Namen des Schauspielers von der Akteur-Tabelle zu verbinden?

Ich denke, ich brauche eine Form von:

WHERE actor.actor_id = film_actor.actor_id. 

Antwort

0

Sie benötigen eine einfache Innen zwischen dem Tisch verbinden actors und der Tisch actors_film:

SELECT a.actor_name, a.actor_id, COUNT(*) 
    FROM actors a INNER JOIN actors_films af 
     ON a.actor_id = af.actor_id 
GROUP BY a.actor_name, a.actor_id 
ORDER BY 3; 
+0

bearbeitet, danke. –

+0

Dies hat nun das Problem, dass Schauspieler mit dem gleichen Namen (aber unterschiedlicher 'actor_id') als identisch gezählt werden. Sie brauchen beide in der 'Gruppe von' –

+0

Das ist super, danke! Werde versuchen, mehr über die Kapitel über Join zu lesen. Aber das war eine große Hilfe, nochmals vielen Dank! –