AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

HAVING mit MAX (alias)

Ein Thema von MrSpock · begonnen am 6. Jul 2012 · letzter Beitrag vom 8. Jul 2012
Antwort Antwort
Furtbichler
(Gast)

n/a Beiträge
 
#1

AW: HAVING mit MAX (alias)

  Alt 7. Jul 2012, 17:14
Hi Spock

Ich habe 0 Ahnung von mysql und deshalb sind meine Vorschläge nur Theorie.
Wenn mySQL mit Variablen umgehen kann, könntest Du dir die höchste Anzahl in einer Variablen merken und dann auf die 2.Tabelle verzichten.
So z.B.
SQL-Code:
DECLARE maxAnzahl INT
create Temporary table Anzahl (id int, Anz int)
insert into Anzahl select id, count(*) from myTable
select max(Anz) from Anzahl into maxAnzahl
select * from Anzahl where Anz = @maxAnzahl
DROP TABLE Anzahl
Wäre denkbar, das das nur in einer Prozedur oder einem BEGIN-END Block geht.

Geändert von Furtbichler ( 7. Jul 2012 um 17:19 Uhr)
  Mit Zitat antworten Zitat
Namenloser

Registriert seit: 7. Jun 2006
Ort: Karlsruhe
3.724 Beiträge
 
FreePascal / Lazarus
 
#2

AW: HAVING mit MAX (alias)

  Alt 7. Jul 2012, 18:00
Die Lösung von Bummi und mir macht letztlich ja auch nichts anderes, nur dass die temporäre Tabelle nicht explizit angelegt wird.
SQL-Code:
select max(anz) from (
  select count(*) as anz from Tabelle group by id /* ← temporäre Tabelle */
)
  Mit Zitat antworten Zitat
Furtbichler
(Gast)

n/a Beiträge
 
#3

AW: HAVING mit MAX (alias)

  Alt 7. Jul 2012, 19:34
Na doch. Mr.Spock möchte alle Einträge, deren Spalte 'ID' am häufigsten vorkommt.
Deine Query liefert nur die maximale Anzahl.

Der kleine Frickelansatz von mir liefert zumindest die Spalten 'ID'
  Mit Zitat antworten Zitat
Namenloser

Registriert seit: 7. Jun 2006
Ort: Karlsruhe
3.724 Beiträge
 
FreePascal / Lazarus
 
#4

AW: HAVING mit MAX (alias)

  Alt 8. Jul 2012, 00:00
Na doch. Mr.Spock möchte alle Einträge, deren Spalte 'ID' am häufigsten vorkommt.
Deine Query liefert nur die maximale Anzahl.
Nö.
  Mit Zitat antworten Zitat
Benutzerbild von Valle
Valle

Registriert seit: 26. Dez 2005
Ort: Karlsruhe
1.223 Beiträge
 
#5

AW: HAVING mit MAX (alias)

  Alt 8. Jul 2012, 08:43
Was ist damit?

[SQL]select * from test where value = (select max(value) from test);[/SQL]

Hat in meinen Tests funktioniert und ist irgendwie das einfachste?

Liebe Grüße,
Valentinf
Valentin Voigt
BOFH excuse #423: „It's not RFC-822 compliant.“
Mein total langweiliger Blog
  Mit Zitat antworten Zitat
Furtbichler
(Gast)

n/a Beiträge
 
#6

AW: HAVING mit MAX (alias)

  Alt 8. Jul 2012, 10:32
Na doch. Mr.Spock möchte alle Einträge, deren Spalte 'ID' am häufigsten vorkommt.
Deine Query liefert nur die maximale Anzahl.
Nö.
Wir reden aneinander vorbei: Mein 'Na doch' bezieht sich auf deinen letztgenannten Vorschlag:
Die Lösung von Bummi und mir macht letztlich ja auch nichts anderes, nur dass die temporäre Tabelle nicht explizit angelegt wird.
SQL-Code:
select max(anz) from (
  select count(*) as anz from Tabelle group by id /* ← temporäre Tabelle */
)
Und das ist etwas komplett anderes, als das, was gefordert wurde.

Die von Dir zuvor präsentierten Lösungen (auf die Du dich im 'Nö' beziehst) funktionieren ja, aggregieren aber zweimal. Und ich habe eine Alternative vorgeschlagen, in der 'GROUP BY' nur 1x vorkommt.
  Mit Zitat antworten Zitat
tgvoelker

Registriert seit: 9. Sep 2002
Ort: Oelsnitz, Vogtland
44 Beiträge
 
Delphi 12 Athens
 
#7

AW: HAVING mit MAX (alias)

  Alt 8. Jul 2012, 11:58
Code:
SELECT id, count(wert) as anz
GROUP BY id
HAVING (anz = MAX(anz))
Das kann nicht funktionieren, weil Du ein einfaches Aggregat eines Wertes mit einem mehrfachen Aggregat desselben vergleichen willst - was innerhalb einer SQL-Ebene (deren Aggregationsregeln Du mit GROUP BY definierst) unzulässig ist. Du erkennst das daran, daß MAX(ANZ) gruppenübergreifend ermittelt werden soll.

Where schränkt übrigens die ursprünglichen Datenmengen ein, d.h. wirkt vor der Gruppierung, kann deshalb die Aggregate nicht kennen.

Die folgende Syntax funktioniert (auf mySQL 5.1 getestet)

Code:
select
FileExt
,count(FileId) as Anz
from
filetable
group by FileExt
having
Anz=(select max(subanz) from (select count(FileId) as subanz from filetable group by FileExt)as subtab)
"FileExt" wäre Dein "ID", "FileId" entspräche Deinem "wert".
Thomas Völker
  Mit Zitat antworten Zitat
Namenloser

Registriert seit: 7. Jun 2006
Ort: Karlsruhe
3.724 Beiträge
 
FreePascal / Lazarus
 
#8

AW: HAVING mit MAX (alias)

  Alt 8. Jul 2012, 19:05
Zitat:
SQL-Code:
select max(anz) from (
  select count(*) as anz from Tabelle group by id /* ← temporäre Tabelle */
)
Und das ist etwas komplett anderes, als das, was gefordert wurde.

Die von Dir zuvor präsentierten Lösungen (auf die Du dich im 'Nö' beziehst) funktionieren ja
Schon mal was von „Auszug“ gehört?
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 09:51 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz