1. Dashboard
  2. Forum
    1. Unerledigte Themen
  3. Mitglieder
    1. Letzte Aktivitäten
    2. Benutzer online
    3. Team-Mitglieder
    4. Trophäen
    5. Mitgliedersuche
  4. Tutorial Bereich
  • Anmelden
  • Registrieren
  • Suche
Dieses Thema
  • Alles
  • Dieses Thema
  • Dieses Forum
  • Seiten
  • Forum
  • Lexikon
  • Erweiterte Suche
  1. Informatik Forum
  2. Webmaster & Internet
  3. Entwicklung

sql frage

  • 3M@2mv
  • 13. Dezember 2010 um 07:36
  • Unerledigt
  • 3M@2mv
    4
    3M@2mv
    Mitglied
    Punkte
    110
    Beiträge
    15
    • 13. Dezember 2010 um 07:36
    • #1

    Hallo Leute,
    ich habe eine Frage über SQL-Abfrage.Ich habe die gesammte Anzahl die Schülern auf jede angegebene Gymnasium die in Wien stehen gefunden aber ich möchte nur eine von denen ausgeben,welche die maximale Anzahl hat.So gebe ich alle aus aber das ist nicht was ich will.Wie kann ich nur eins ausgeben?


    select Klassen.Schulen_id,Schulen.Schulen_name,sum (anzahl) as Summe
    from Klassen, Schulen
    where Schulen.Schulen_id = Klassen.Schulen_id and Schulen.adresse like "*Wien*"
    GROUP BY Klassen.Schulen_id,Schulen.Schulen_name
    ORDER BY Klassen.Schulen_id;

    mfG

    5 Mal editiert, zuletzt von 3M@2mv (13. Dezember 2010 um 13:04)

  • Shardik
    12
    Shardik
    Mitglied
    Reaktionen
    16
    Punkte
    1.351
    Beiträge
    248
    • 13. Dezember 2010 um 08:57
    • #2
    Code
    select * 
    from Schulen join Klassen on Klassen.ID = Schulen.ID
    where Klassen.Anzahl = (select MAX(Anzahl) from Klassen)

    :(){ :|:&};:

  • freiBär
    8
    freiBär
    Mitglied
    Reaktionen
    47
    Punkte
    687
    Beiträge
    124
    • 13. Dezember 2010 um 08:59
    • #3

    Probiers mal in der where Klausel mit sum(anzahl) >=ALL(select sum (anzahl)
    Von Klassen, Schulen
    where Schulen.Schulen_id = Klassen.Schulen_id and Schulen.adresse like "*Wien*"
    GROUP BY Klassen.Schulen_id,Schulen.Schulen_name
    ORDER BY Klassen.Schulen_id);

    Sollte dir dann nur den Eintrag mit der größten Anzahl ausgeben.

    Why?... Because we can take it. We are not heroes, we just love science. We are silent guardians, watchful protectors of knowledge. We are dark knights (sometimes in white labcoats).

    freiBär für alle!
    https://twitter.com/freiBaer

  • 3M@2mv
    4
    3M@2mv
    Mitglied
    Punkte
    110
    Beiträge
    15
    • 13. Dezember 2010 um 13:37
    • #4

    Hallo,

    freiBär,sum(anzahl) >=ALL(select sum (anzahl) from Klassen) so ähnliches struktur habe ich auch probiert aber leider ich kriege syntax fehler.
    Eigentlich logischeweise das muss gehen aber ich weiß nicht vielleicht wegen Access sein.

    Shardik, ich muss zu erst die gesammte Anzahl von Schülern finden, dann die größte Anzahl von diese Ergebnisse muss ich ausgeben.

    ------------------------------------------------

    Grundsätzlich wie kann man so was machen ?
    Alle A1,A2,A3 und A4 addieren

    Spalte1- Spalte2

    A1-------- 20
    A2-------- 24
    A2-------- 33
    A1-------- 22
    A2-------- 23
    A3-------- 28
    A4-------- 29
    A3-------- 33

    A1= 42 , A2=80 , A3=61 , A4=29 so habe ich alle addiert jetzt möchte ich nur das größte Ergebnis ausgeben.Hier es ist --> A2. Wie kann ich nur A2 ausgeben?

  • Shardik
    12
    Shardik
    Mitglied
    Reaktionen
    16
    Punkte
    1.351
    Beiträge
    248
    • 13. Dezember 2010 um 14:22
    • #5

    Ich glaub' du suchst das TOP Keyword.

    SQL
    SELECT TOP 1 Schulen.ID, SUM(Anzahl) as Summe
    FROM Schulen JOIN Klassen ON Klassen.ID = Schulen.ID
    WHERE Schulen.Adresse LIKE '%Wien%'
    GROUP BY Schulen.ID
    ORDER BY Summe

    ggf. Syntax umschreiben, kA ob Access jetzt TOP/LIMIT/'/"/*/% verwendet

    :(){ :|:&};:

  • 3M@2mv
    4
    3M@2mv
    Mitglied
    Punkte
    110
    Beiträge
    15
    • 13. Dezember 2010 um 18:45
    • #6

    Shardik,ich könnte es nicht machen aber vielleicht kannst du mir diese Frage antworten.Dann kann ich vielleicht was machen.

    Tabelle1
    ------------------------------------------
    gruppe- anzahl

    A1-------- 20
    A2-------- 24
    A2-------- 33
    A1-------- 22
    A2-------- 23
    A3-------- 28
    A4-------- 29
    A3-------- 33

    A1= 42 , A2=80 , A3=61 , A4=29 so habe ich die Gruppen addiert jetzt möchte ich nur das größte Ergebnis ausgeben.Hier es ist --> A2. Wie kann ich nur A2 ausgeben?

    Danke
    mfG

    Einmal editiert, zuletzt von 3M@2mv (13. Dezember 2010 um 21:18)

  • Maximilian Rupp 27. Dezember 2024 um 00:26

    Hat das Thema aus dem Forum Programmieren nach Entwicklung verschoben.

Jetzt mitmachen!

Sie haben noch kein Benutzerkonto auf unserer Seite? Registrieren Sie sich kostenlos und nehmen Sie an unserer Community teil!

Benutzerkonto erstellen Anmelden

Benutzer online in diesem Thema

  • 2 Besucher

Rechtliches

Impressum

Datenschutzerklärung