AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi SQL Summe und Berechnung
Thema durchsuchen
Ansicht
Themen-Optionen

SQL Summe und Berechnung

Ein Thema von pbfdg · begonnen am 16. Sep 2006 · letzter Beitrag vom 18. Sep 2006
Antwort Antwort
Seite 1 von 2  1 2      
pbfdg

Registriert seit: 13. Mär 2005
16 Beiträge
 
#1

SQL Summe und Berechnung

  Alt 16. Sep 2006, 00:16
Datenbank: Firebird • Version: 1.53 • Zugriff über: Zeos 6.1.5
Hallo
folgendes Problem!

Programm Erklärung:
Kalkulation von Werkzeugen (Formenbau).

Tabellen (ausschnitt):

Tabelle 1:
Werkzeug
Felder:
ID;Nummer;Typ .. usw.

Tabelle 2:
Vorkalkulation
Felder:
ID;WERKZEUG_ID;Gruppe;Std;Kosten

Tabelle 3:
Nachkalkulation
Felder:
ID;WERKZEUG_ID;Gruppe;Std;Kosten


Nach der Erstellung einer Vorkalkulation(Tabelle 2) habe ich pro Werkzeug dann 31 Datensätze wobei jeder Datensatz eine Gruppe darstellt.

Nun werden nach und nach Nachkalkulations Datensätze eingegeben. Es können dann mehrere Datensätze für die verschiedenn Gruppe entstehen.


Nun möchte ich in einer SQL-Abfrage folgende Felder haben.

Felder:
Gruppe;SollStd;SollKosten;IstStd;IstKosten;Rest;Pr ozent

Mein Ansatz!

select v.gruppe, sum(v.std) as sollstd, sum(v.kosten) as sollkosten, sum(n.std) as iststd, sum(n.kosten) as istkosten, (sum(v.kosten) - sum(n.kosten)) as rest, (sum(n.kosten) / (sum(v.kosten)*100)) as prozent
from vorkal v
inner join nachkalkulation n on v.vorkal_id = n.vorkal_id
where (v.vorkal_id = werkzeug.id)
group by v.gruppe

Das Ergebnis dieser Abfrage ist leider nicht korrekt!
Wer kann mir auf die Sprünge helfen?


Gruß Peter
  Mit Zitat antworten Zitat
Hansa

Registriert seit: 9. Jun 2002
Ort: Saarland
7.554 Beiträge
 
Delphi 8 Professional
 
#2

Re: SQL Summe und Berechnung

  Alt 16. Sep 2006, 01:43
Zitat von pbfdg:
Das Ergebnis dieser Abfrage ist leider nicht korrekt!
Wer kann mir auf die Sprünge helfen
Viele, aber es wird nicht gesagt, was inkorrekt ist. 8)
Gruß
Hansa
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#3

Re: SQL Summe und Berechnung

  Alt 16. Sep 2006, 08:58
Hallo Peter,

bei der Einführung von Tabelle3 ist dir wohl ein Schreibfehler unterlaufen: statt WERKZEUG_ID sollte es wohl VORKAL_ID heißen. Durch die Verkettung (JOIN) zweier 1:n-Beziehungen in einem Statement werden die Summen für die Vorkalkulation um ein Vielfaches zu hoch ausfallen, weil für jedes Tupel aus Tabelle3 die Werte aus Tabelle2 erneut aufsummiert werden.

Grüße vom marabu
  Mit Zitat antworten Zitat
pbfdg

Registriert seit: 13. Mär 2005
16 Beiträge
 
#4

Re: SQL Summe und Berechnung

  Alt 16. Sep 2006, 16:27
Hallo marabu,
du hast recht, die Summen stimmen nicht.
Für jeden Datensatz in der Nachkalkulation wird der Wert in der Vorkalkulation multipliziert.
Ich habe mal ein Bild erstellt indem die Tabellen mit Datensätzen zu sehen sind. Über den einzelnen Tabellen habe ich mal eine Erklärung geschrieben.
Hier nochmal meine SQL-Abfrage die zum Bild paßt:
select n.gruppe, sum(v.std) as sollstd, sum(v.kosten) as soll, sum(n.std) as std, sum(n.betrag) as ist, (sum(v.kosten) - sum(n.betrag)) as rest, (sum(n.betrag) / (sum(v.kosten+0.0001)*100)) as prozent
from vorkal v
inner join nachkalkulation n on v.gruppe = n.gruppe
where (v.vorkal_id = :id) and (n.vorkal_id = :id)
group by n.gruppe
order by n.gruppe




Nun die Frage wie kann ich das lösen?

Gruß Peter
Miniaturansicht angehängter Grafiken
summen_160.jpg  
  Mit Zitat antworten Zitat
omata

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

Re: SQL Summe und Berechnung

  Alt 16. Sep 2006, 21:53
Hallo pbfdg,

vielleicht so...

SQL-Code:
SELECT v.gruppe
       SUM(v.std) AS sollstd,
       SUM(v.kosten) AS soll
       COALESCE(n.std, 0) AS std,
       COALESCE(n.ist, 0) AS ist,
       SUM(v.kosten) - COALESCE(n.ist, 0) AS rest,
       COALESCE(n.ist, 0) / (SUM(v.kosten+0.0001)*100) AS prozent
FROM vorkal v
LEFT JOIN (SELECT gruppe,
                  SUM(n.std) AS std,
                  SUM(n.betrag) AS ist
           FROM nachkalkulation
           WHERE vorkal_id = :id
           GROUP BY gruppe) n
  ON v.gruppe = n.gruppe
WHERE v.vorkal_id = :id
GROUP BY v.gruppe
ORDER BY v.gruppe
Deine komische Prozentspalte verstehe ich allerdings nicht so ganz.

Gruss
Thorsten
  Mit Zitat antworten Zitat
pbfdg

Registriert seit: 13. Mär 2005
16 Beiträge
 
#6

Re: SQL Summe und Berechnung

  Alt 17. Sep 2006, 13:03
Hallo omata,

erst einmal DANKE für die Hilfe, aber leider bekomme ich eine Fehlermeldung (siehe Bild).
Mein SQL ist nicht so gut um das ganze zu verstehen.

Das was ich verstanden habe ist.
Hinter dem LEFT JOIN wird eine Unterabfrage erzeugt indem die Summen in der Nachkalkulation gebildet wird. Diese werden wiederum zur Verrechnung mit der Vorkalkulation herangezogen.

Die Fehlermeldung bezieht sich auf "(Select ...."

Hast Du vielleicht noch einen Ansatz?

Gruß Peter
Miniaturansicht angehängter Grafiken
fehlermeldung_174.jpg  
  Mit Zitat antworten Zitat
omata

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

Re: SQL Summe und Berechnung

  Alt 17. Sep 2006, 21:18
Hallo pbfdg,

stimmt meine Überlegung war noch nicht ganz korrekt.

Ein neuer Versuch...

SQL-Code:
SELECT v.gruppe,
       SUM(v.std) AS sollstd,
       SUM(v.kosten) AS soll,
       COALESCE(n.std, 0) AS std,
       COALESCE(n.ist, 0) AS ist,
       SUM(v.kosten) - COALESCE(n.ist, 0) AS rest,
       (100.00 * COALESCE(n.ist, 0)) / SUM(v.kosten) AS prozent
FROM vorkal v
LEFT JOIN (SELECT gruppe,
                  SUM(std) AS std,
                  SUM(kosten) AS ist
           FROM nachkalkulation
           WHERE vorkal_id = :id
           GROUP BY gruppe) n
  ON v.gruppe = n.gruppe
WHERE v.vorkal_id = :id
GROUP BY v.gruppe, n.std, n.ist
ORDER BY v.gruppe
Gruss
Thorsten
  Mit Zitat antworten Zitat
pbfdg

Registriert seit: 13. Mär 2005
16 Beiträge
 
#8

Re: SQL Summe und Berechnung

  Alt 17. Sep 2006, 23:19
Hallo omata,

ich habe die SQL-Sequenz mal durch den SQL-Manager laufen lassen und folgende Fehlermeldung erhalten.
(siehe Bild)

Wenn ich meine Schriftlichen unterlagen zu rate ziehe sollte deine SQL-Sequenz eigentlich korrekt sein.


Gruß Peter
Miniaturansicht angehängter Grafiken
fehlermeldung2_340.jpg  
  Mit Zitat antworten Zitat
omata

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

Re: SQL Summe und Berechnung

  Alt 18. Sep 2006, 00:32
Vielleicht liegt es ja an deiner Firebird-Version. Mit 2.0 geht die Abfrage wunderbar.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.861 Beiträge
 
Delphi 11 Alexandria
 
#10

Re: SQL Summe und Berechnung

  Alt 18. Sep 2006, 11:14
Zitat von omata:
Vielleicht liegt es ja an deiner Firebird-Version. Mit 2.0 geht die Abfrage wunderbar.
Da die Abfarge ja das neue Feature der "Derived Tables" nutzt, hierbei wird eine Abfrage wie eine Tabelle verwendet.
Markus Kinzler
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 04:24 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