Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Phänomenale Fehlermeldung unter Vista...zum Rätseln (https://www.delphipraxis.net/129854-phaenomenale-fehlermeldung-unter-vista-zum-raetseln.html)

haentschman 27. Feb 2009 12:00

Re: Phänomenale Fehlermeldung unter Vista...zum Rätseln
 
Danke für deine Antwort,

Ich muß dich aber enttäuschen..
Zitat:

dann Ändere doch mal das Endedatum vom Februar auf 27.02.2009
...jedes Datum erzeugt den Fehler sofern es sich im Februar aufhält :wink:

Zitat:

sondern kann auch durch fehlerhafte Daten in der Ergebnismenge
...die Tabelle ist, was den Februar betrifft leer, also Count=0 :gruebel:

...ich liebe Vista :evil:

:hi:

Sir Rufo 27. Feb 2009 12:03

Re: Phänomenale Fehlermeldung unter Vista...zum Rätseln
 
Zitat:

Zitat von haentschman
Zitat:

Nicht jeder Februar hat 29 Tage.
:-D dafür ist IsLeapYear da und das Datum im Parameter ist der 28.02.2009 weil wir dieses Jahr kein Schaltjahr haben

Bei meinen Code brauchst du kein IsLeapYear mehr ;)

haentschman 27. Feb 2009 12:08

Re: Phänomenale Fehlermeldung unter Vista...zum Rätseln
 
:wink: weis ich, aber das Zitat stammte aus einer Antwort vor deiner Version mit EncodeDate.

nahpets 27. Feb 2009 12:37

Re: Phänomenale Fehlermeldung unter Vista...zum Rätseln
 
Hallo,
Zitat:

Zitat von haentschman
Danke für deine Antwort,

Ich muß dich aber enttäuschen..
Zitat:

dann Ändere doch mal das Endedatum vom Februar auf 27.02.2009
...jedes Datum erzeugt den Fehler sofern es sich im Februar aufhält :wink:

Zitat:

sondern kann auch durch fehlerhafte Daten in der Ergebnismenge
...die Tabelle ist, was den Februar betrifft leer, also Count=0 :gruebel:

...ich liebe Vista :evil:

:hi:

füg' einen Satz für Februar ein. Ist der Fehler dann weg, dann kommt da wer nicht mit 'ner leeren Ergebnismenge zurecht (zugegeben: Das ist absurd).

Also dann mal bitte mit:
Delphi-Quellcode:
'select count(ID) from BEHANDLUNG where DATUM >= :Datum1 and DATUM <= :Datum2 and KUNDENNUMMER = :Kunde';
dann mit
Delphi-Quellcode:
'select count(ID) from BEHANDLUNG where KUNDENNUMMER = :Kunde and DATUM between :Datum1 and :Datum2';
dann mit
Delphi-Quellcode:
'select count(ID) from BEHANDLUNG where 1 = 2 and KUNDENNUMMER = :Kunde and DATUM between :Datum1 and :Datum2';
dann mit
Delphi-Quellcode:
'select count(ID) from BEHANDLUNG where KUNDENNUMMER = :Kunde and DATUM between :Datum1 and :Datum2';
wobei :Datum1 = 31.01.2009 und :Datum2 = 01.03.2009.
dann mit
Delphi-Quellcode:
'select count(ID) from BEHANDLUNG where KUNDENNUMMER = :Kunde and DATUM > :Datum1 and DATUM < :Datum2';
wobei :Datum1 = 31.01.2009 und :Datum2 = 01.03.2009.

Gibt es auch andere Monate, in denen Count = 0 ist?
Wenn nein, dann mal für alle Monate probieren:
Delphi-Quellcode:
'select count(ID) from BEHANDLUNG where 1 = 2 and KUNDENNUMMER = :Kunde and DATUM between :Datum1 and :Datum2';
Das muss also immer eine leere Ergebnismenge liefern. Wenn's jetzt immer kracht, dann liegt das Problem nicht im Datum, sondern in der leeren Ergebnismenge.

Wenn's dann immer noch nicht geht, werden für Februar Betriebsferien angeordnet 8)

haentschman 27. Feb 2009 12:42

Re: Phänomenale Fehlermeldung unter Vista...zum Rätseln
 
:wink: das riecht ja nach richtig Arbeit deine Vorschläge :wink:

...werd ich der Reihe nach mal abarbeiten. :thumb:

Die leere Ergebnismenge sollte kein Problem darstellen, da auch andere Monate Count=0 haben und sich nicht beschweren.

Zitat:

Wenn's dann immer noch nicht geht, werden für Februar Betriebsferien angeordnet
diese Idee hatte ich auch schon :-D

Danke für deine Zeit...ich melde mich dann. PS: kann etwas dauern, sorry :(

hoika 27. Feb 2009 13:06

Re: Phänomenale Fehlermeldung unter Vista...zum Rätseln
 
Hallo,

definier doch mal anständige Variablen tdtStartDate, tdtEndDate (TDateTime)
oder sStartDate, sEndDate (String).

Besser ist halt AsDate (AsDateTime) zu verwenden.

Dann Breakpoint drauf und guggern.


Ich habe FB2.0.3 mal ausprobiert.
Die Meldung kommt nur, wenn das Datum falsch ist.


Heiko

haentschman 14. Mär 2009 16:35

Re: Phänomenale Fehlermeldung unter Vista...zum Rätseln
 
Sorry für die späte Antwort...

Delphi-Quellcode:
ZQueryStatistikKunde.SQL.Text:= 'select count(ID) from BEHANDLUNG where DATUM between :Datum1 and :Datum2 and KUNDENNUMMER = :Kunde';
ZQueryStatistikKunde.ParamByName('Datum1').AsDate:= StartOfAMonth(Jahr,M);
ZQueryStatistikKunde.ParamByName('Datum2').AsDate:= EndOfAMonth(Jahr,M);
ZQueryStatistikKunde.ParamByName('Kunde').asString:= 'STRING';
ZQueryStatistikKunde.Open;
- auch diese Variante bringt die Exception
- auch verschiedene feste "Februar Werte" erzeugen den Fehler
- sobald der Parameter Kunde im "STRING" ein alphanumerisches Zeichen enthält kommt der Fehler
- Parameter Kunde nur mit Zahlen im String, Bsp: '1234' laufen auch im Februar durch

...ich bin noch nicht schlauer :(

Danke an alle :wink:


UPDATE:

- nach vielen Probierereien, auch mit anderen Zugriffskomponenten, das Ergebnis:

:warn: trotzdem ich alle Daten mit diversen Tools lesen kann...die Datenbank selbst ist fehlerhaft, warum auch immer :gruebel:

- das mit dem Vista war nur, weil ich mit 2 Datenbanken entwickelt habe und die korrupte auf dem Vista lag. :roll:

Danke an alle für die Hilfe :hi:

Satty67 14. Mär 2009 16:58

Re: Phänomenale Fehlermeldung unter Vista...zum Rätseln
 
Vielleicht die Abfrage mal umstellen, wenn Kunde auch Einfluss auf den Fehler hat:
SQL-Code:
select count(ID) from BEHANDLUNG where DATUM between :Datum1 and :Datum2 and KUNDENNUMMER = :Kunde

zu

select count(ID) from BEHANDLUNG where KUNDENNUMMER = :Kunde and DATUM between :Datum1 and :Datum2

haentschman 14. Mär 2009 19:29

Re: Phänomenale Fehlermeldung unter Vista...zum Rätseln
 
Danke für Deine Hilfe :wink:

das einzige, was was gebracht hat war eine neue Spalte anlegen, die Daten in die neue Spalte, Spalte Kundennummer löschen, Spalte Kundennummer neu und die Daten wieder zurück....oder die komplette DB neu erzeugen.

Warum die Spalte so ein merkwürdiges Problem hatte...nicht nachvollziehbar :gruebel:

Danke für Eure Zeit... :hi:


Alle Zeitangaben in WEZ +1. Es ist jetzt 03:20 Uhr.
Seite 2 von 2     12   

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