AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

MySQL - Group by und Count

Ein Thema von Matze · begonnen am 25. Feb 2008 · letzter Beitrag vom 25. Feb 2008
Antwort Antwort
Seite 2 von 2     12   
omata

Registriert seit: 26. Aug 2004
Ort: Nebel auf Amrum
3.154 Beiträge
 
Delphi 7 Enterprise
 
#11

Re: MySQL - Group by und Count

  Alt 25. Feb 2008, 14:51
Hier noch ein Versuch...

SQL-Code:
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
Gruss
Thorsten
  Mit Zitat antworten Zitat
Benutzerbild von Matze
Matze
(Co-Admin)

Registriert seit: 7. Jul 2003
Ort: Schwabenländle
14.929 Beiträge
 
Turbo Delphi für Win32
 
#12

Re: MySQL - Group by und Count

  Alt 25. Feb 2008, 15:01
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
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.542 Beiträge
 
Delphi 11 Alexandria
 
#13

Re: MySQL - Group by und Count

  Alt 25. Feb 2008, 15:10
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%')
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von Matze
Matze
(Co-Admin)

Registriert seit: 7. Jul 2003
Ort: Schwabenländle
14.929 Beiträge
 
Turbo Delphi für Win32
 
#14

Re: MySQL - Group by und Count

  Alt 25. Feb 2008, 18:12
Zitat von DeddyH:
Ist die Gruppierung nicht überflüssig?
Zitat von Matze:
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.


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.

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.

Auf jedenfall vielen Dank für eure Mithilfe!
Miniaturansicht angehängter Grafiken
result_913.png   articles_data_100.png   articles_696.png  
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


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 05:58 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