AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Problem mit select-Anweisung
Thema durchsuchen
Ansicht
Themen-Optionen

Problem mit select-Anweisung

Ein Thema von Ykcim · begonnen am 13. Sep 2013 · letzter Beitrag vom 16. Sep 2013
Antwort Antwort
Ykcim

Registriert seit: 29. Dez 2006
Ort: NRW
824 Beiträge
 
Delphi 10.4 Sydney
 
#1

Problem mit select-Anweisung

  Alt 13. Sep 2013, 12:07
Datenbank: MySQL • Version: 5 • Zugriff über: UniDac
Hallo Zusammen,

sorry für den nicht aussagekräftigen Titel, aber ich weiß nicht, wie ich das Problem in ein Wort packen soll...

Ich habe eine Tablle mit folgender Struktur
1. AuftragsNr (Auftrag)
2. ArtikelNr (Artikel)
3. Arbeitsgang (AG)
4. Status (S) 0=nicht fertig; 9=fertig
5. Maschine (MA)
6. Gefertigte Menge (Menge)

Das Ganze sieht dann so ähnlich aus:

Auftrag...Artikel...AG...S...MA...Menge
1000001...4711000...10...9...P1...10000
1000001...4711000...20...9...C2....9950
1000001...4711000...30...0...V4.......0
1000001...4711000...40...0...S1.......0
1000001...4711000...50...0...W5.......0
1000999...0815000...10...9...P1...10000
1000999...0815000...20...9...V4...10000
1000999...0815000...30...9...C2....9998
1000999...0815000...40...9...W5....9990
1000999...0815000...50...0...S1.......0
1000999...0815000...60...0...Y1.......0
1000999...0815000...70...0...Q1.......0

Dise Tabelle besteht aus mehreren 100T Datensätzen.

Ich muss jetzt zwei Dinge herausfinden und weiß noch nicht wir ich das anstellen soll:
1. Ich brauche die Summe der Mengen aller zuletzt fertiggemeldeten Arbeitsgänge. Bei AUftrag 1000001 sind das der AG 20 mit 9950 und bei Auftrag 1000999 ist der AG 40 mit 9990, also in Summe 19940.
2. Ich brauche in einer anderen Abfrage den naächst folgenden Arbeitsgang. Also bei 1000001 den AG 30 und bei dem Auftrag 1000999 den AG 50.

Hat jemand eine Idee, wie ich das anstellen muss?

Vielen Dank
Patrick
Patrick

Geändert von Ykcim (13. Sep 2013 um 12:10 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.624 Beiträge
 
Delphi 12 Athens
 
#2

AW: Problem mit select-Anweisung

  Alt 13. Sep 2013, 13:29
Ein Ansatz zu Frage1: bekommst Du hiermit die richtigen Datensätze zum Aufaddieren?
SQL-Code:
SELECT
  Menge
FROM
  Tabelle Haupt
WHERE
  Arbeitsgang =
  (SELECT
     MAX(Arbeitsgang)
   FROM
     Tabelle
   WHERE
     Status = 9
     AND
       Auftrag = Haupt.Auftrag
  )
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Darlo

Registriert seit: 28. Jul 2008
Ort: München
1.196 Beiträge
 
Delphi 10.2 Tokyo Enterprise
 
#3

AW: Problem mit select-Anweisung

  Alt 13. Sep 2013, 13:39
Ein Ansatz zu Frage1: bekommst Du hiermit die richtigen Datensätze zum Aufaddieren?
SQL-Code:
SELECT
  Menge
FROM
  Tabelle Haupt
WHERE
  Arbeitsgang =
  (SELECT
     MAX(Arbeitsgang)
   FROM
     Tabelle
   WHERE
     Status = 9
     AND
       Auftrag = Haupt.Auftrag
  )
Wenn das geht, dann für den 2. Punkt
[code]
SQL-Code:
SELECT
  Menge
FROM
  Tabelle Haupt
WHERE
  Arbeitsgang =
  (SELECT
     MIN(Arbeitsgang)
   FROM
     Tabelle
   WHERE
     Status = 0
     AND
       Auftrag = Haupt.Auftrag
  )
Philip
  Mit Zitat antworten Zitat
jaevencooler

Registriert seit: 8. Sep 2005
Ort: Friedrichshafen
41 Beiträge
 
Delphi 10 Seattle Enterprise
 
#4

AW: Problem mit select-Anweisung

  Alt 16. Sep 2013, 12:39
Moin, Moin,



das sollte per SQL möglich sein, was ich aber nicht so ganz verstehe
ist warum einmal AG20 und dann AG40, da ja der Status = 9 bei mehreren
Datensätzen mit der gleichen Auftragsnummer vorkommt...


1000001...4711000...10...9...P1...10000 <-
1000001...4711000...20...9...C2....9950 <-
1000001...4711000...30...0...V4.......0
1000001...4711000...40...0...S1.......0
1000001...4711000...50...0...W5.......0

warum die Summe aus AG20 und nicht aus AG10 ??

Gruß
Michael
Michael
Wissen ist Macht, nichts wissen macht auch nichts.
  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 08:21 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