AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren

HAVING mit MAX (alias)

Ein Thema von MrSpock · begonnen am 6. Jul 2012 · letzter Beitrag vom 9. Jul 2012
Antwort Antwort
Seite 1 von 3  1 23   
Benutzerbild von MrSpock
MrSpock
(Co-Admin)

Registriert seit: 7. Jun 2002
Ort: Owingen
5.865 Beiträge
 
Delphi 2010 Professional
 
#1

HAVING mit MAX (alias)

  Alt 6. Jul 2012, 20:05
Datenbank: MYSQL • Version: 5.1 • Zugriff über: Konsole
Hallo,

warum funktioniert folgende query nicht?

Code:
SELECT id, count(wert) as anz
GROUP BY id
HAVING (anz = MAX(anz))
Idee ist, dass ich die Einträge finde, die in der Spalte anz (alias für count(wert)) den maximalen Wert haben.

Interessanterweise werden alle Werte gezeigt, wenn ich schreibe

Code:
HAVING (Max(anz) = 0)
anz hat aber für alle Datensätze einen Wert > 0 !?
Albert
Live long and prosper


MrSpock
  Mit Zitat antworten Zitat
Benutzerbild von Bummi
Bummi

Registriert seit: 15. Jun 2010
Ort: Augsburg Bayern Süddeutschland
3.470 Beiträge
 
Delphi XE3 Enterprise
 
#2

AW: HAVING mit MAX (alias)

  Alt 6. Jul 2012, 20:14
Keine Ahnung wie weit MySQL inzwischen mit Subselects ist, geht sowas?
Code:
HAVING (Count(*) = (Select MAX(ANZ) from (SELECT id, count(wert) as anz
from ??
GROUP BY id) ))
Thomas Wassermann H₂♂
Das Problem steckt meistens zwischen den Ohren
DRY DRY KISS
H₂ (wenn bei meinen Snipplets nichts anderes angegeben ist Lizenz: WTFPL)
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#3

AW: HAVING mit MAX (alias)

  Alt 6. Jul 2012, 20:29
So sollte das eigentlich funktionieren
SQL-Code:
SELECT * FROM (
  SELECT id, count(wert) as anz
  GROUP BY id
) as tmp
WHERE anz = MAX( anz );
aber das geht auch:
SQL-Code:
SELECT * FROM (
  SELECT id, count(wert) as anz
  GROUP BY id
) as tmp
ORDER BY anz DESC
LIMIT 1;
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
Benutzerbild von MrSpock
MrSpock
(Co-Admin)

Registriert seit: 7. Jun 2002
Ort: Owingen
5.865 Beiträge
 
Delphi 2010 Professional
 
#4

AW: HAVING mit MAX (alias)

  Alt 6. Jul 2012, 20:39
Hallo Sir Rufo,

so hab ich es auch schon versucht. Das Problem ist aber, dass mir immer nur ein Datensatz ausgegeben wird, obwohl mehrere den maximalen Wert haben.

bei anz = Max(anz) muss die HAVING Clause benutzt werden, weil where keine Aggregatfunktionen erlaubt
Albert
Live long and prosper


MrSpock

Geändert von MrSpock ( 6. Jul 2012 um 20:43 Uhr)
  Mit Zitat antworten Zitat
Namenloser

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

AW: HAVING mit MAX (alias)

  Alt 6. Jul 2012, 21:09
Warum es nicht funktioniert, kann ich dir auch nicht sagen, aber ich habe mal eben ein paar Varianten durchprobiert, und folgendes scheint zu funktionieren:

select * from Tabelle join (select max(Spalte) as maximum from Tabelle) as tmp on maximum=Spalte
  Mit Zitat antworten Zitat
Benutzerbild von MrSpock
MrSpock
(Co-Admin)

Registriert seit: 7. Jun 2002
Ort: Owingen
5.865 Beiträge
 
Delphi 2010 Professional
 
#6

AW: HAVING mit MAX (alias)

  Alt 6. Jul 2012, 22:10
Hallo Philip,

ich benötige ja das Maximum einer (alias Spalte), die wiederum eine Aggregatfunktion nutzt.
Albert
Live long and prosper


MrSpock
  Mit Zitat antworten Zitat
nahpets
(Gast)

n/a Beiträge
 
#7

AW: HAVING mit MAX (alias)

  Alt 6. Jul 2012, 22:52
Hallo,

mir ist es nur auf diese Art gelungen (allerdings kein MySQL):
Code:
select id, anz from (
  select id, count(wert) as anz
  from tabelle
  group by id
) a
where anz = (
  select max(anz) from (
    select id, count(wert) as anz
    from tabelle
    group by id
  )
)
Mit Having scheint es nicht unbedingt zu gehe(?)
  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 6. Jul 2012, 23:02
Hallo Philip,

ich benötige ja das Maximum einer (alias Spalte), die wiederum eine Aggregatfunktion nutzt.
Ah sorry, hatte ich irgendwie falsch gesehn.

Ich habe folgende Varianten anzubieten:
SQL-Code:
select
  id,
  count(*) as anz,
  (
    select max(anz)
    from (select count(*) as anz from Tabelle group by id) as tmp
  ) as maximum
from Tabelle
group by id
having anz=maximum
SQL-Code:
select id, count(*) as anz
from Tabelle
group by id
having
  (
    select max(anz)
    from (select count(*) as anz from Tabelle group by id) as tmp
  ) = anz

Geändert von Namenloser ( 7. Jul 2012 um 19:00 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Bummi
Bummi

Registriert seit: 15. Jun 2010
Ort: Augsburg Bayern Süddeutschland
3.470 Beiträge
 
Delphi XE3 Enterprise
 
#9

AW: HAVING mit MAX (alias)

  Alt 6. Jul 2012, 23:56
die von mir ursprünglich vorgeschlagene Lösung
Code:
SELECT id, count(*) as anz
from test
GROUP BY id
HAVING Count(*) = (Select MAX(ANZ) from (SELECT id, count(*) as anz
from test
GROUP BY id) i)
funktioniert unter MSSQL.
Funktioniert sie unter MySQL nicht?
Thomas Wassermann H₂♂
Das Problem steckt meistens zwischen den Ohren
DRY DRY KISS
H₂ (wenn bei meinen Snipplets nichts anderes angegeben ist Lizenz: WTFPL)

Geändert von Bummi ( 7. Jul 2012 um 13:40 Uhr)
  Mit Zitat antworten Zitat
Furtbichler
(Gast)

n/a Beiträge
 
#10

AW: HAVING mit MAX (alias)

  Alt 7. Jul 2012, 08:25
warum funktioniert folgende query nicht?
Weil die Syntax falsch ist: Du wendest in der HAVING-Klausel ein Aggregat auf eine Spalte der Ergebnistabelle an. Erlaubt sind jedoch nur Aggregate auf Spalten der Ursprungstabelle.
Zitat:
Interessanterweise werden alle Werte gezeigt, wenn ich schreibe
Code:
HAVING (Max(anz) = 0)
Ich finde das nicht interessant, sondern typisch mySQL.

Der Weg führt imho nur über eine 'temporäre Tabelle', d.h. die Aggregat-Tabelle mit den Spalten id und Anz (also Count(*)). Davon möchstest Du die Einträge, deren Wert Anz am größten ist.

Bei meiner Arbeit mit MSSQL ist mir aufgefallen, das die Verwendung temporärer Tabellen häufiger wesentlich performanter ist, leichter verständlich und schneller zum Ziel führt:
SQL-Code:
select Id, Count(*) as Anz into #temp from myTable group by Id
select * from #temp where Anz = (select max(Anz) from #temp)
Kennt mySQL temporäre Tabellen oder Tabellenvariablen? ....*gugel* ja, geht
SQL-Code:
create Temporary table Anzahl (id int, Anz int)
insert into Anzahl select id, count(*) from myTable
select * from Anzahl where Anz = (select max(Anz) from Anzahl)
DROP TABLE Anzahl
Hier scheint es so zu sein, das eine Lösung mit einem Statement nur über den Klimmzug geht, die Aggregattabelle 'Select id, count(*)...' mehrfach zu verwenden. Schafft der Compiler es, dies zu erkennen und das Aggregat nur 1x durchzuführen?
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 3  1 23   

Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

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 13:52 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz