AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi [SQL] Summen verschiedener Abfragekriterien in einer Abfrage
Thema durchsuchen
Ansicht
Themen-Optionen

[SQL] Summen verschiedener Abfragekriterien in einer Abfrage

Ein Thema von Captnemo · begonnen am 4. Jul 2003 · letzter Beitrag vom 5. Jul 2003
Antwort Antwort
Benutzerbild von Captnemo
Captnemo

Registriert seit: 27. Jan 2003
Ort: Bodenwerder
1.126 Beiträge
 
Delphi XE4 Architect
 
#1

[SQL] Summen verschiedener Abfragekriterien in einer Abfrage

  Alt 4. Jul 2003, 18:13
Hi Leute,

ich hab da ein Problem, bei dem ich nicht weiter weiß.
Vorweg; Ich bin kein SQL-Profi. Ich benutze MySQL.

Zum Problem. Ich habe eine Tabelle, in der Währungswerte und Datumswerte einhalten sind.
z.B.
Einkaufsdatum
Einkaufspreis
Verkaufspreis

usw.

Jetzt möchte ich die Summen und die Durchschnittswerte der einzelnen Monate.

Ich hatte es probiert mit folgendem Syntax:
SQL-Code:
Select SUM(Einkaufspreis where MONTH(Einkaufsdatum)="4") AS April,
       SUM(Einkaufspreis where MONTH(Einkaufsdatum)="5") AS Mai
from einkauf
Funktioniert natürlich nicht. Aber wie kann man das lösen.
Ist für euch Crack doch kein Problem
Dieter
9 von 10 Stimmen in meinem Kopf sagen ich bin nicht verrückt. Die 10. summt dazu die Melodie von Supermario Bros.
MfG Captnemo
  Mit Zitat antworten Zitat
Hansa

Registriert seit: 9. Jun 2002
Ort: Saarland
7.554 Beiträge
 
Delphi 8 Professional
 
#2
  Alt 4. Jul 2003, 19:39
Die Hauptfrage weiß ich jetzt nicht, denn ich habe mit der SQL-Syntax auch noch zu kämpfen. Aber diese Seite ist die beste, die ich bisher gesehen habe (kurz, aber nicht zu knapp mit Beispielen) :

http://www.w3schools.com/sql/

@Mods: wäre überlegenswert, den Link irgendwo bei FAQ oder so abzulegen.
Gruß
Hansa
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

Registriert seit: 29. Mai 2002
Ort: Frankfurt
8.251 Beiträge
 
Delphi 2006 Professional
 
#3

Re: [SQL] Summen verschiedener Abfragekriterien in einer Abf

  Alt 4. Jul 2003, 21:08
Hai Captnemo,

in diesem Fall hilf dir die GroupBy Funktion. Zwar nicht genau wie du wolltest aber es sollte gehen.

SQL-Code:
SELECT SUM(einkaufspreis) AS summe, MONTH(Einkaufsdatum) AS monat, YEAR(Einkaufsdatum) AS Jahr
FROM Summen
GROUP BY MONTH(Einkaufsdatum), YEAR(Einkaufsdatum)
Jetzt bekommst Du für jeden Monat und jedes Jahr einen Wert mit der Summe.

Sieht dann so aus.

Code:
summe monat jahr
12     5      2002
99     6      2002
8      5      2003
57     6      2003
Wenn du das oft in deinem Programm brauchst empfehle ich dies als View in deinem SQL-Server abzulegen und dann die Daten aus dieser mit den nötigen Einschränkunden auszulesen.

In etwa so:

SQL-Code:
CREATE VIEW View_Summe
AS
SELECT SUM(wert) AS summe, MONTH(datum) AS Monat,
    YEAR(datum) AS Jahr
FROM Summen
GROUP BY MONTH(datum), YEAR(datum)
Dann kannst Du die Summen für einen Monat ganz einfach auslesen.

SELECT summe FROM View_Summe WHERE (monat = 5) AND (jahr = 2003)
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  Mit Zitat antworten Zitat
JoelH
(Gast)

n/a Beiträge
 
#4

hmm,

  Alt 5. Jul 2003, 00:51
@sharky

aber auch nur wenn die DB views versteht !!
  Mit Zitat antworten Zitat
Benutzerbild von Captnemo
Captnemo

Registriert seit: 27. Jan 2003
Ort: Bodenwerder
1.126 Beiträge
 
Delphi XE4 Architect
 
#5
  Alt 5. Jul 2003, 18:02
Dank an Hansa. Dein Link hat mich weitergebracht.

Dank auch an Sharky. Auf die gleiche Lösung bin ich dann mit hilfe von Hansa's Link auch gekommen. Aber trotzdem vielen Dank.
Dieter
  Mit Zitat antworten Zitat
Hansa

Registriert seit: 9. Jun 2002
Ort: Saarland
7.554 Beiträge
 
Delphi 8 Professional
 
#6
  Alt 5. Jul 2003, 18:18
Find ich gut, daß auch mal eine Frage mit Hilfe eines Links geklärt werden kann, die zumindest ich nicht wußte. Deshalb wiederhole ich mich nochmals:

Zitat von Hansa:
http://www.w3schools.com/sql/

@Mods: wäre überlegenswert, den Link irgendwo bei FAQ oder so abzulegen.
Gruß
Hansa
  Mit Zitat antworten Zitat
Antwort Antwort


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 20:41 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