Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit
GELÖST

SQL Abfrage

Frage Entwicklung PHP

Mitglied: datadexx

datadexx (Level 1) - Jetzt verbinden

27.01.2013, aktualisiert 28.01.2013, 1803 Aufrufe, 3 Kommentare

Hi Leute,

ich verzweifel mal wieder an einer Abfrage, bzw. an deren Aufbau.

Folgender Ausgang.

Die Tabelle Posten hat die unter anderem die Spalten Gesamt, Unternehmer, TransAnr, status

Die Spalte Gesamt enthält immer die Summe des einzlnen Posten (was dem Kunden für diesen Posten in Rechnung gestellt wird), die Spalte Unternehmer was der Unternehmer bekommt.

Die Spalte TransAnr kann auch den Wert "Gutschrift" enthalten, dann darf der Posten nicht mit in die Berechnung der Summe "Gesamt" einfliessen.

Die Spalte status kann verschiedene INT Werte enthalten, für die Summe der Spalte "Gesamt" darf sie nicht den Wert 3 & 4 haben, für die Summe der Spalte "Unternehmer" nicht den Wert 3 haben.

Ich möchte nun den monatlichen Gewinn ermitteln und diesen ausgeben, meine bisherige Abfrage sieht so aus:
Da fehlt aber die Geschichte mit dem status !=4 für die Berechnung der Summe "Gesamt". Ich denke das wird mit einer if Abfrage für die Summe "Gesamt" gemacht, weiß aber nicht wie.

SELECT MONTH(DATUM) AS Monat,
SUM(Gesamt) - SUM(Unternehmer) AS Summe
FROM posten
WHERE YEAR(DATUM) = YEAR(NOW())
AND status !=3
AND TransAnr !='Gutschrift'
GROUP BY 1

Das ergibt einen Fehler im Ergebnis. Eigentlich brauche ich das Ergebnis (SUMME) von den beiden folgenden Abfragen in einer Abfrage.

SELECT (SUM(Gesamt)) summe FROM posten WHERE status !=3 AND status !=4 AND posten.TransAnr !='Gutschrift' AND YEAR(DATUM) = YEAR(NOW())

- (minus)

SELECT (SUM(Unternehmer)) summe FROM posten WHERE status !=3 AND YEAR(DATUM) = YEAR(NOW())

= Ergebnis netto Gewinn

VIELEN DANK AN ALLE IM VORAUS!!!!
Mitglied: LianenSchwinger
28.01.2013, aktualisiert um 07:56 Uhr
Hallo,

versuch mal folgendes:

01.
SELECT MONTH(p.datum) AS Monat, 
02.
       SUM(IF(p.status != 3 AND p.status != 4, p.gesamt, 0) - 
03.
       SUM(IF(p.status != 3, p.unternehmer, 0) Summe 
04.
FROM POSTEN AS p 
05.
WHERE p.transanr != 'Gutschrift' 
06.
AND YEAR(p.datum) = YEAR(NOW()) 
07.
GROUP BY MONTH(p.datum)
Gruß Jörg
Bitte warten ..
Mitglied: datadexx
28.01.2013 um 16:45 Uhr
Hi Jörg,

nachdem ich die fehlenden Klammern von SUM noch hinzugefügt habe, hat es geklappt.

Vielen Dank dafür!!!
Bitte warten ..
Mitglied: LianenSchwinger
28.01.2013 um 17:24 Uhr
Ups, ist mir das peinlich

Dann warten wir mal auf die nächste Frage.

Gruß Jörg
Bitte warten ..
Neuester Wissensbeitrag
Windows 10

Powershell 5 BSOD

(8)

Tipp von agowa338 zum Thema Windows 10 ...

Ähnliche Inhalte
Datenbanken
gelöst SQL-Abfrage - DISTINCT - letztes Datum (3)

Frage von emeriks zum Thema Datenbanken ...

Datenbanken
SUM oder AVG in SQL Abfrage dauert viel zu lange warum? (5)

Frage von samet22 zum Thema Datenbanken ...

Datenbanken
gelöst SQL-Abfrage mit MAX() (9)

Frage von FrAmEr zum Thema Datenbanken ...

Datenbanken
gelöst Schleifen in SQL-Abfrage bei 2 Tabellen (2)

Frage von Aximand zum Thema Datenbanken ...

Heiß diskutierte Inhalte
Microsoft
Ordner mit LW-Buchstaben versehen und benennen (20)

Frage von Xaero1982 zum Thema Microsoft ...

Outlook & Mail
gelöst Outlook 2010 findet ost datei nicht (19)

Frage von Floh21 zum Thema Outlook & Mail ...

Netzwerkmanagement
gelöst Anregungen, kleiner Betrieb, IT-Umgebung (18)

Frage von Unwichtig zum Thema Netzwerkmanagement ...

Festplatten, SSD, Raid
M.2 SSD wird nicht erkannt (14)

Frage von uridium69 zum Thema Festplatten, SSD, Raid ...