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, 1815 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 ..
Ähnliche Inhalte
Datenbanken
gelöst Verschachtelte SQL-Abfrage (4)

Frage von User1000 zum Thema Datenbanken ...

Datenbanken
gelöst SQL-Abfrage und leere Felder vermeiden (12)

Frage von zwangseinweisung zum Thema Datenbanken ...

Datenbanken
gelöst SQL-Abfrage - Anzahl der Wechsel zählen (15)

Frage von Cire48 zum Thema Datenbanken ...

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

Frage von emeriks zum Thema Datenbanken ...

Heiß diskutierte Inhalte
Verschlüsselung & Zertifikate
gelöst Festplattenverschlüsselung im Ausland (13)

Frage von Nicolaas zum Thema Verschlüsselung & Zertifikate ...

Festplatten, SSD, Raid
gelöst Fehlerhafte Blöcke im RAID 10 (12)

Frage von Kojak-LE zum Thema Festplatten, SSD, Raid ...

Windows Server
gelöst Microsoft-Lizenz CALs und passendes Server-Betriebssystem (12)

Frage von planetIT2016 zum Thema Windows Server ...

Netzwerkgrundlagen
gelöst Cisco SG500 Series LAG hat sich von selbst umgestellt (11)

Frage von Ex0r2k16 zum Thema Netzwerkgrundlagen ...