Zum Inhalt springen
View in the app

A better way to browse. Learn more.

Fachinformatiker.de

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

Frage zu einem Join

Empfohlene Antworten

Veröffentlicht

Hallo,

ich hab da ein kleines Problem mit einem Join.

Und zwar will ich mit einem SELECT gewisse Spalten einer Tabelle Abfragen.

Diese Tabelle ist mit einer 1 zu X Verknüfung mit einer andren Tabelle verbunden.

Wie bekomme ich nun mittels einem SQL String die Informationen aus der "Haupttabelle" und als Wert noch dabei die Anzahl der Datensätze in der Verknüpften Tabelle?

Bisher hatte ich es mit einem Subselect auf der InterBase gemacht, aber da ich das Programm auf MySQL Portieren will, muss ich das abändern. Während des Durchlaufen des Recordsets einen neuen SQL Abzuschießen um die Datensätze zu Zählen würde ich gerne Vermeiden.

Danke schonmal im Vorraus!

Gruß,

Michael Schmuck

Du musst die zwei Tabellen mit einem Join verknüpfen und in der untergeordneten tabelle mit count(*) die Tupel zählen. Damit Du pro Datensatz der Vatertabelle eine Anzahl bekommst, musst Du die Vatertabelle nach dem Primärschlüssel gruppieren.

Hier ein Beispiel, angenommen Bestellung sei die Vatertabelle (mit Primärschlüssel Bestellnummer) und BPosition die abhängige Tabelle (mit Fremdschlüssel Bestellnummer). Dann bekommst Du mit

select b.bestellnummer, count(*) as Anzahl

from Bestellung b join BPosition p on p.bestellnummer=b.bestellnummer

group by b.bestellnummer

zu jedem Datensatz in der Vatertabelle "Bestellung" die Anzahl der in der abhängigen Tabelle "BPosition" enthaltenen Datensätze.

Gruß

Alex

Hallo,

hört sich gut an bis jetzt, leider klappts noch nicht 100%ig

ich habe nun folgendes:

 

select

  p.id,

  p.name,

  count(*) as anz

from

  todo_projekte p join todo_aufgaben a on p.id = a.projekt

group by

  p.id

Jedoch bringt mit meine InterBase folgende Meldung:

Dynamic SQL Error.

SQL error code = -104.

invalid column reference.

Ich habe jeweils auf der Projekt und Aufgabentabelle einen Uniqe Key auf dem ID Feld.

Gruß,

Michael Schmuck

Achtung, Du darfst bei einer Gruppierung nur Gruppierungsspalten und Aggregatfunktionen in der SELECT-Liste haben! Wenn Du also außer der ID unbedingt den Namen noch brauchst, muss die Abfrage so aussehen:


select

  p.id,

  p.name,

  count(*) as anz

from

  todo_projekte p join todo_aufgaben a on p.id = a.projekt

group by

  p.id, p.name

Gruß

Alexander

Archiv

Dieses Thema wurde archiviert und kann nicht mehr beantwortet werden.

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.