www.mikrocontroller.net

Forum: PC-Programmierung SQL: Daten in Tabelle zusammenfassen.


Autor: Karl (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Hallo,

habe da ein kleines Problem mit SQL(ite).
Habe eine Tabelle in der Werte und das Datum steht.
|Wert|Datum|

Jetzt möchte ich gerne alle diese Daten Monatsweise für jeden Tag 
zusammenfassen/summieren.
|Summe aller 01.|Summe aller 02.| ... |Summe aller 30.|Summe aller 31.|

Damit ich einen Monatsverlauf darstellen kann, bzw die Summe über alle 
Monate.

Kann mir da jemand einen Tipp geben?
Mein großes Problem ist halt aus den Daten der ersten Tabelle zur Form 
der zweiten Tabelle zu kommen, das summieren ist ja mit SUM() kein 
Problem...

Gruß
Karl

Autor: Peter (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
soetwas geht leider nicht schön in SQL.

in T-Sql von MS müsste es so gehen.


select
   ( select sum(xx) from Tab where day( datum ) = 1 ) as Summe1,
   ( select sum(xx) from Tab where day( datum ) = 2 ) as Summe2,
   ( select sum(xx) from Tab where day( datum ) = 3 ) as Summe3,
   ...
   ( select sum(xx) from Tab where day( datum ) = 30 ) as Summe30,
   ( select sum(xx) from Tab where day( datum ) = 31 ) as Summe31

Autor: mike (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
versuchs mit

GROUP BY Datum

Autor: Peter (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
mike schrieb:
> versuchs mit
>
> GROUP BY Datum

aufgabe nicht verstanden?
Er will die Tage nebeneinander stehen haben, in der Tabelle stehen die 
werte aber untereinandern. Das bekommt man mit einem einfachen "Group 
by" nicht hin!

Autor: Karl (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
@Peter

Danke, so gehts. Ist aber auch echt aufwendig.
Unter SQLite sieht es genau so aus
select sum(xx) from Tab where strftime("%d", fahrt.datum) = 1 ) as Summe1

Autor: Karl (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Uh, da ist mir ein Fehler unterlaufen, richtig ist:
select sum(xx) from Tab where strftime("%d", fahrt.datum) = "01" ) as Summe1


Antwort schreiben

Die Angabe einer E-Mail-Adresse ist freiwillig. Wenn Sie automatisch per E-Mail über Antworten auf Ihren Beitrag informiert werden möchten, melden Sie sich bitte an.

Wichtige Regeln - erst lesen, dann posten!

  • Groß- und Kleinschreibung verwenden
  • Längeren Sourcecode nicht im Text einfügen, sondern als Dateianhang

Formatierung (mehr Informationen...)

  • [c]C-Code[/c]
  • [avrasm]AVR-Assembler-Code[/avrasm]
  • [code]Code in anderen Sprachen, ASCII-Zeichnungen[/code]
  • [math]Formel in LaTeX-Syntax[/math]
  • [[Titel]] - Link zu Artikel
  • Verweis auf anderen Beitrag einfügen: Rechtsklick auf Beitragstitel,
    "Adresse kopieren", und in den Text einfügen




Bild automatisch verkleinern, falls nötig
Bitte das JPG-Format nur für Fotos und Scans verwenden!
Zeichnungen und Screenshots im PNG- oder
GIF-Format hochladen. Siehe Bildformate.
Hinweis: der ursprüngliche Beitrag ist mehr als 6 Monate alt.
Bitte hier nur auf die ursprüngliche Frage antworten,
für neue Fragen einen neuen Beitrag erstellen.

Mit dem Abschicken bestätigst du, die Nutzungsbedingungen anzuerkennen.