AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren

HAVING mit MAX (alias)

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

n/a Beiträge
 
#6

AW: HAVING mit MAX (alias)

  Alt 7. Jul 2012, 07: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
 

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:47 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