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?
Hallo Bummi,
die Abfrage ist Wirklichkeit deutlich komplexer, deshalb war es mit dem Testen nicht so einfach. Ich habe es aber nochmal ausprobiert und behaupte, dass es nicht funktioniert!
Es wird mir kein Datensatz ausgegeben. Ich vermute, dass die Gleichung in der Having Clause nicht funktioniert.
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
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?
OK, diese Lösung scheint mir wirklich die beste zu sein. Ein Problem hat
MySQL aber noch mit dem
select * from #temp where Anz = (select max(Anz) from #temp)
in einer Abfrage kann eine temporary table offensichtlich nicht zweimal benutzt werden. Deshalb musste ich noch eine zweite temp table benutzen