AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren

SUM mit DATEDIFF

Ein Thema von ThomasWB · begonnen am 11. Nov 2019 · letzter Beitrag vom 12. Nov 2019
Antwort Antwort
jobo

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

AW: SUM mit DATEDIFF

  Alt 12. Nov 2019, 09:56
Zitat:
bekomme ich den Fehler "Fehler beim Konvertieren einer Zeichenfolge in ein Datum."
Wenn man dieserFehlermeldung glauben kann, dann sitzt der Fehler hier
Code:
(R.wert2 AS time)
oder hier
Code:
(R.wert3 AS time)
Ich würde jetzt nicht darüber diskutieren ob dieser Fehler möglich ist oder nicht, sondern ich würde mir die Daten einmal anschauen.
Ich würde das unterstützen und trotzdem darüber diskutieren.

Auch auf die "Gefahr" hin, dass es nicht der Grund für den Fehler ist:
Wie kommt man gerade als Pascal Entwickler darauf, dass die Konvertierung eines beliebigen Wertes in Datum oder Zeittypen einfach so funktioniert?
Wieso bin ich immer wieder überrascht, dass soetwas gemacht wird?

Es handelt sich hier offenbar nicht um eine implizite Konvertierung, aber ohne (sichtbar) Vorgabe, wie wert2 oder wert3 aufgebaut ist, ist eine fehlerhafte Datengrundlage im CAST Vorgang doch naheliegend. Es gibt weitere Indizien dafür:
- der (einfache) Ausdruck funktioniert (scheinbar)
- SUM über den gleichen (einfachen) Ausdruck funktioniert nicht

Was passiert da wohl?
Ich mache ein Probeselekt auf meine Tabelle, mein modernes Tool liefert natürlich nicht 1000e Datensätze zurück, sondern liefert intelligent ein paar Werte von Anfang der Tabelle. Ich bilde nun die Summe über den "funktionierenden" Ausdruck. Summen gehen bekanntlich über alles, also die ganze Tabelle. Hier gibt es keine "Intelligenz" mehr im Tool, es wird einfach geliefert, jeder(!) Feldwert wird angefasst, blind gecastet und aufsummiert. Das geht natürlich leicht in die Hose, wenn die Werte die dabei verwurstet werden nicht auf anderer Ebene (Constraints, Business Logik, ..) ein garantiertes Format aufweisen.

ps: Dieser Gedanke ist leicht prüfbar, z.B. das "funktionierende" Statement ganz durchlaufen lassen
Gruß, Jo

Geändert von jobo (12. Nov 2019 um 09:58 Uhr)
  Mit Zitat antworten Zitat
Jumpy

Registriert seit: 9. Dez 2010
Ort: Mönchengladbach
1.740 Beiträge
 
Delphi 6 Enterprise
 
#2

AW: SUM mit DATEDIFF

  Alt 12. Nov 2019, 11:29
Was passiert, wenn man die Summe mal anders bildet?

SQL-Code:
Select Sum(Wert) From
(

SELECT
       CAST(
            DATEDIFF(hh,
                     (R.von + CAST(R.wert2 AS time)),
                     (R.bis + CAST(R.wert3 AS time))
                    )
            AS int
           ) as Wert
FROM auplan R

)
Ralph
  Mit Zitat antworten Zitat
Antwort Antwort

Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

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 07:33 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz