AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken sql-Abfrage Artikel aufsummieren nach Produktionszeit
Thema durchsuchen
Ansicht
Themen-Optionen

sql-Abfrage Artikel aufsummieren nach Produktionszeit

Ein Thema von Rainer Wolff · begonnen am 10. Dez 2010 · letzter Beitrag vom 11. Dez 2010
Antwort Antwort
Rainer Wolff

Registriert seit: 25. Okt 2005
Ort: Bretten
321 Beiträge
 
Delphi 10.4 Sydney
 
#1

sql-Abfrage Artikel aufsummieren nach Produktionszeit

  Alt 10. Dez 2010, 15:28
Datenbank: egal • Version: - • Zugriff über: -
Hallo

ich möchte eine Tabelle mit Produktionsdaten zusammenfassen. Die Einträge sind sinngemäß so:

Datum-Zeit; Artikel

10.12.2010 9:00; "Artikel A"
10.12.2010 9:01; "Artikel A"
10.12.2010 9:02; "Artikel A"
10.12.2010 9:03; "Artikel B"
10.12.2010 9:04; "Artikel B"
10.12.2010 9:05; "Artikel A"
10.12.2010 9:06; "Artikel A"

Herauskommen soll dann eine Aufsummierung von allen Artikeln, die direkt nacheinander gefertigt wurden, also in etwa:

"Artikel A"; 3 Stück; (am besten gleich noch mit Uhrzeit 9:00-9:02)
"Artikel B"; 2 Stück; (am besten gleich noch mit Uhrzeit 9:03-9:04)
"Artikel A"; 2 Stück; (am besten gleich noch mit Uhrzeit 9:06-9:06)

Gibt es dazu einen mächtigen sql-Ausdruck, oder muss ich das Hand bei Fuß mit Durchlaufen der Tabelle und programmintern Aufsummieren erledigen?

Gruß Rainer
  Mit Zitat antworten Zitat
Benutzerbild von joachimd
joachimd

Registriert seit: 17. Feb 2005
Ort: Weitingen
679 Beiträge
 
Delphi 12 Athens
 
#2

AW: sql-Abfrage Artikel aufsummieren nach Produktionszeit

  Alt 10. Dez 2010, 15:49
Herauskommen soll dann eine Aufsummierung von allen Artikeln, die direkt nacheinander gefertigt wurden, also in etwa:

"Artikel A"; 3 Stück; (am besten gleich noch mit Uhrzeit 9:00-9:02)
"Artikel B"; 2 Stück; (am besten gleich noch mit Uhrzeit 9:03-9:04)
"Artikel A"; 2 Stück; (am besten gleich noch mit Uhrzeit 9:06-9:06)
ungestestet:
SELECT Artikel, Count(*), MIN(Datum-Zeit), MAX(Datum-Zeit) FROM Produktionsdaten GROUP BY Artikel sorry...habe gerade gesehen, dass Du eine Reihenfolge brauchst...bleibt nur Scripting (Stored Procedure) bzw clientseitige aufsummierung.
Joachim Dürr
Joachim Dürr Softwareengineering
http://www.jd-engineering.de

Geändert von joachimd (10. Dez 2010 um 15:50 Uhr) Grund: was übersehen :(
  Mit Zitat antworten Zitat
Benutzerbild von mschaefer
mschaefer

Registriert seit: 4. Feb 2003
Ort: Hannover
2.032 Beiträge
 
Delphi 12 Athens
 
#3

AW: sql-Abfrage Artikel aufsummieren nach Produktionszeit

  Alt 10. Dez 2010, 16:30
Moin,

würde das noch anders angehen. Eigentlich brauchst Du einen Marker,
wann der Artikel gewechselt wird. Am besten wäre das schon beim
Eintragen in der Datenbank. Oder aber man läßt eine Procedure laufen.

Delphi-Quellcode:
CREATE PROCEDURE GET_GRP_NO RETURNS
(
  GROUP_NO INTEGER,

  Datum DATE,
  Zeit TIME1
  Artikel VARCHAR(10)

) AS

DECLARE VARIABLE iCOUNT INTEGER;
DECLARE VARIABLE iARTIKEL CHAR(10);
BEGIN
  iCOUNT = 0;
  iARTIKEL = "";
  FOR SELECT Datum, Zeit, Artikel
      FROM Tabelle
      INTO :Datum, :Zeit, :Artikel
  DO
  BEGIN
      if iARTIKEL <> Artikel
        THEN iCOUNT = iCOUNT + 1
      ;
      GROUP_NO = iCOUNT;
      iARTIKEL = Artikel
    SUSPEND;
  END
END
^
Danach kann man dann eine SQL auf die GROUP_NO gruppieren:


Delphi-Quellcode:

SELECT DISTINCT ARTIKEL,
       COUNT (Artikel),
       MIX (TIME),
       MAN (TIME),
       FROM Tabelle
       GROUP BY GROUP_NO
       ORDER BY GROUP_NO
Grüße
Martin Schaefer
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#4

AW: sql-Abfrage Artikel aufsummieren nach Produktionszeit

  Alt 11. Dez 2010, 09:24
Hallo Martin,

die Db ist ja egal laut Anforderung, aber zu welcher DB gehört die Procedure GET_GRP_NO RETURNS? Funktioniert das?

Gruß, Jo
  Mit Zitat antworten Zitat
Benutzerbild von Bummi
Bummi

Registriert seit: 15. Jun 2010
Ort: Augsburg Bayern Süddeutschland
3.470 Beiträge
 
Delphi XE3 Enterprise
 
#5

AW: sql-Abfrage Artikel aufsummieren nach Produktionszeit

  Alt 11. Dez 2010, 09:33
@jobo

das was das Beispiel für eine selbst zu erstellende Prozedur.
Zitat:
CREATE PROCEDURE GET_GRP_NO RETURNS
Mit der Anforderung DB egal wirst Du nicht weit kommen.
Du wirst in jedem Fall eine Prozedur benötigen und dort Temporärtabellen und gegf. Cursor.

Unter MSSQL kein Problem, ich nehme an Oracle und Firebird dürften derartigen auch unterstützen, MYSQL keine Ahnung, Access nicht Nettwerktauglich mit einer harten "Temporärtabelle"...
Thomas Wassermann H₂♂
Das Problem steckt meistens zwischen den Ohren
DRY DRY KISS
H₂ (wenn bei meinen Snipplets nichts anderes angegeben ist Lizenz: WTFPL)
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#6

AW: sql-Abfrage Artikel aufsummieren nach Produktionszeit

  Alt 11. Dez 2010, 11:24
Hallo Bummi,

danke dir, aber ich wollte gern wissen, was das für eine DB ist, die diese Prozedur "versteht". Ich arbeite fast nur mit Oracle, daher kann ich mich nicht entscheiden, ob die angeführte Prozedur eine Art Muster sein soll oder wirklich auf einem bestimmten RDBMS läuft.

Eine Prozedur dazu ist natürlich kein Problem, ein Select wäre aber viel toller.

Gruß, Jo
  Mit Zitat antworten Zitat
Benutzerbild von mschaefer
mschaefer

Registriert seit: 4. Feb 2003
Ort: Hannover
2.032 Beiträge
 
Delphi 12 Athens
 
#7

AW: sql-Abfrage Artikel aufsummieren nach Produktionszeit

  Alt 11. Dez 2010, 12:04
Moin, moin zusammen,

also die Procedure ist jetzt von Firebird, aber das PSQL von FB ist von Oracle PL/SQL ja auch nicht so weit weg.

Grüße
Martin Schaefer
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#8

AW: sql-Abfrage Artikel aufsummieren nach Produktionszeit

  Alt 11. Dez 2010, 12:15
Tag,

..ja auch nicht so weit weg..
das war das, was mich stutzig gemacht hat. Denn ich finde schon, dass es ganz anders aussieht (als in Oracle). Naja, mein Problem, dann muss ich mir vielleicht mal Firebird anschauen.
So, genug OT.

Schönes Wochenede
Jo
  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 19:32 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