![]() |
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 20:01 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