![]() |
Datenbank: MySQL • Version: >= 4.1.13
MySQL - Group by und Count
Hallo,
ich komme bei einer SQL-Abfrage, die ich für eine Suchfunktion nutze, nicht weiter. Die Suchergebnisse zu ermitteln klappt ohne Probleme:
SQL-Code:
ad.active kann pro ad.article_id (diese kann mehrmals vorkommen) nur genau einmal 1 sein, dennoch benötige ich das GROUP BY, da sonst mehrere Einträge mit gleicher ad.article_id aufgelistet werden. Wieso auch immer. :gruebel:
SELECT ad.article_id, a.title FROM articles a
LEFT JOIN articles_data ad ON ad.article_id = a.article_id AND ad.show_flag = 0 AND ad.active = 1 WHERE a.text LIKE '%blubb%' OR a.title LIKE '%blubb%' GROUP BY ad.article_id ORDER BY ad.date DESC Auf jedenfall erhalte ich dadurch meine Suchergebnisse und ich würde sagen, diese stimmen. Nun habe ich versucht, die Anzahl der Einträge bei dem oben zurückgelieferten Ergebnis mit fast der gleichen Abfrage zu ermitteln, doch das klappt nicht. Da kommt immer ein falscher Wert heraus:
SQL-Code:
Es kann gut sein, dass ich wieder komplett falsch joine, doch ich habe die Joins eigentlich alle durchprobiert.
SELECT COUNT(a.article_id) as 'count' FROM articles a
LEFT JOIN articles_data ad ON ad.article_id = a.article_id AND ad.show_flag = 0 AND ad.active = 1 WHERE a.text LIKE '%blubb%' OR a.title LIKE '%blubb%' GROUP by ad.article_id Was mache ich falsch? Grüße |
Re: MySQL - Group by und Count
Versuch mal
SQL-Code:
SELECT COUNT(ad.article_id) as 'count' FROM articles a
LEFT JOIN articles_data ad ON ad.article_id = a.article_id AND ad.show_flag = 0 AND ad.active = 1 WHERE a.text LIKE '%blubb%' OR a.title LIKE '%blubb%' GROUP by ad.article_id |
Re: MySQL - Group by und Count
Hallo Frank,
das hatte ich auch bereits getestet, doch da kommt dann immer 0 raus. Grüße Edit: Oder halt, mein SQL-Client liefert mir da ein Array, das die richtige Anzahl an Einträgen entält. Ich hätte jedoch gerne eine einzige Zahl.
Code:
count
----- 0 7 4 7 ... |
Re: MySQL - Group by und Count
Dann mus die erste SQL schon eine Fehler haben was kommt den von der 1. SQL für eine Ausgabe
|
Re: MySQL - Group by und Count
Ich würde sagen, dass die Ausgabe der ersten Abfrage stimmt:
Code:
article_id | title
---------------------------- 17 Bla 5 Blubb 10 Wuppdi 16 Moin ... |
Re: MySQL - Group by und Count
Dann stimme die 2. SQL aber versuch mal die 2. SQL im PhpMyAdmin oder in der Mysql Console auszuführen und guck was da kommt.
|
Re: MySQL - Group by und Count
Mein SQL-Client (EMS SQL-Manager) kann SQL-Abfragen ausführen und dieser liefert mir das, was ich oben geschrieben habe.
Edit: Huch, mein Beitragstext wurde nicht dargestellt. |
Re: MySQL - Group by und Count
Vielleicht so...
Alles ausgeben und einzelnd zählen...
SQL-Code:
Nur zählen, was auf die Suche passt...
SELECT a.article_id, a.title, COUNT(*) AS anzahl
FROM articles a INNER JOIN articles_data ad ON a.article_id = ad.article_id WHERE ad.show_flag = 0 AND ad.active = 1 GROUP BY a.article_id, a.title ORDER BY MAX(ad.date) DESC
SQL-Code:
Gruss
SELECT COUNT(*) AS anzahl
FROM articles a INNER JOIN articles_data ad ON a.article_id = ad.article_id WHERE ad.show_flag = 0 AND ad.active = 1 AND ( a.text LIKE '%blubb%' OR a.title LIKE '%blubb%') GROUP BY a.article_id, a.title Thorsten |
Re: MySQL - Group by und Count
Hallo,
ich möchte jedoch nicht alles ausgeben, sondern nur die Einträge, zu denen der Suchbegriff passt. Wenn ich mit der weiter oben geschriebenen Count-Abfrage alle Einträge in ein Array einlese und mittels count() die Anzahl ermittel, dann klappt natürlich alles. Das ist zwar eigentlich nicht Sinn der Sache, denn dann führe ich beinahe 2 identische Abfragen aus, aber zur Not mache ich das so. Grüße |
Re: MySQL - Group by und Count
Vielleicht als ganz simples join:
SQL-Code:
SELECT COUNT(a.article_id) as 'count'
FROM articles a, articles_data ad Where ad.article_id = a.article_id AND ad.show_flag = 0 AND ad.active = 1 AND (a.text LIKE '%blubb%' OR a.title LIKE '%blubb%') GROUP by ad.article_id |
Re: MySQL - Group by und Count
Hier noch ein Versuch...
SQL-Code:
Gruss
SELECT SUM(anzahl) AS anzahl
FROM (SELECT COUNT(*) AS anzahl FROM articles a INNER JOIN articles_data ad ON a.article_id = ad.article_id WHERE ad.show_flag = 0 AND ad.active = 1 AND ( a.text LIKE '%blubb%' OR a.title LIKE '%blubb%') GROUP BY a.article_id, a.title) x Thorsten |
Re: MySQL - Group by und Count
Das könnte funktionieren, nur ersetzt diese Abfrage lediglich die PHP-Funktion count(). Mir kommt es eher so vor, als seien das alles unsaubere Lösungen, ich kann mich natürlich irren. Denn im Endeffekt lese ist jedesmal ein komplettes Array aus und ermittle die Anzahl der Einträge - sei es nun mittels SQL oder PHP.
Dieses Vorgehen würde die SQL-Funktion COUNT() eigentlich komplett überflüssig machen. :? Grüße |
Re: MySQL - Group by und Count
Ist die Gruppierung nicht überflüssig?
SQL-Code:
SELECT COUNT(*) AS anzahl
FROM articles a INNER JOIN articles_data ad ON a.article_id = ad.article_id WHERE ad.show_flag = 0 AND ad.active = 1 AND ( a.text LIKE '%blubb%' OR a.title LIKE '%blubb%') |
Re: MySQL - Group by und Count
Liste der Anhänge anzeigen (Anzahl: 3)
Zitat:
Zitat:
Wenn ich es mache, wie du es vorgeschlagen hast, dann bekomme ich eine Zahl zurückgeliefert, was prinzipiell schon mal nicht schlecht ist, wenn's nur die richtige wäre. :mrgreen: Zum Testen kann man "COUNT(*) AS anzahl" ja durch "*" ersetzen, um zu schauen, was nun für das Zählen benutzt wird. Und da sind leider zahlreiche Einträge aufgeführt, die im zurückgelieferten Ergebnis alle ad.active auf 1 haben, obwohl diese nicht 1 sind, zumindest nicht in den Ausgangsdatensätzen. Im Anhang die Datensätze am Beispiel ad.article_id = 2. "result.png" zeigt das Ergebnis der Abfrage von Detlef, das anstelle von "COUNT ..." ein Sternchen "*" (alles auslesen) enthält. Vielleicht wird es dann etwas klarer. Grüße Edit: Ah, wenn ich das ein wenig vereinfache und nach "id" - nicht "article_id" joine, scheint es zu klappen. Aber das hätte es anders doch auch müssen. :gruebel: Auf jedenfall vielen Dank für eure Mithilfe! |
Alle Zeitangaben in WEZ +1. Es ist jetzt 22:53 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