![]() |
AW: DateTime über ParamByName auf NULL setzen?
Zitat:
Hast Du dazu ein Beispiel, wie es aussehen sollte? Ich bekomme da immer einen Fehler. Mir ist der Aufruf nicht klar. :roll: Danke Gruß Axel |
AW: DateTime über ParamByName auf NULL setzen?
Delphi-Quellcode:
if getBeginDatum > '' then // Datum ist String
DBQuery.ParamByName('P_BeginDatum').AsString := getBeginDatum else DBQuery.ParamByName('P_BeginDatum').Clear; |
AW: DateTime über ParamByName auf NULL setzen?
ganz einfach:
Delphi-Quellcode:
//setzen
DBQuery.ParamByName('P_BeginDatum').clear; //abfragen: if DBQuery.ParamByName('P_BeginDatum').isNull then begin // was auch immer end; |
AW: DateTime über ParamByName auf NULL setzen?
Liste der Anhänge anzeigen (Anzahl: 2)
Zitat:
Vielleicht habe ich nicht klar mein Problem ausgedrückt. Wenn der Anwender kein Datum eingibt, soll auch keins gespeichert werden. Es erscheint aber bei einem leerem Datum 01.01.1900 in der Datenbank.
Delphi-Quellcode:
Wenn ich also auf .isNull abfrage, wüßte ichnicht was ich dort als Wert mitgeben soll. Nur die Clear-Anweisung bringt den Fehler in der Anlage.
if getBeginDatum > '' then
DBQuery.ParamByName('P_BeginDatum').AsString := getBeginDatum else DBQuery.ParamByName('P_BeginDatum').Clear; Grüße Axel |
AW: DateTime über ParamByName auf NULL setzen?
Zitat:
Und soein Scheiß wiederspricht extrem den Paradigmen der Vererbung. Es kann doch nicht sein, dass FieldByName().Value was ganz anderes macht, als über Variablen welche explizit diesen Typen haben, obwohl Beides intern ein TIntergerField ist. |
AW: DateTime über ParamByName auf NULL setzen?
Beim Clear dürfte der Fehler in auftauchen, es schadet aber auch nicht, wenn man den Anweisungen in der Fehlermeldung folgt, die ja sagt, dass der Parameter keinen typ hat und man einen setzten soll!
Der Grund für den falschen Wert wurde Dir zudem schon in #6 genannt. |
AW: DateTime über ParamByName auf NULL setzen?
Ich habe da auch gewisse Probleme mit dem Clear.
Schildere mal kurz was ich will: Es geht um die Verarbeitung von EXCEL-Daten, zurzeit vorallem um Datumseingaben sauber zu verarbeiten. Das Resultat sind Datenbankeinträge und zwar gibt's da nur zwei Fälle: - Das Datum kann wie erwünscht übernommen werden (richtig eingegeben) - Das Datum wurde falsch eingegeben (irgendwelcher String) oder es wurde nichts eingegeben Im ersten Fall soll das Datum in die DB übernommen werden, im zweiten Fall soll ein Leereintrag (kein Defaultdatum oder so) erfolgen. Wie der Leereintrag erfolgt ist nun noch unklar (NULL, ... oder was auch immer). Hoffe es geht ohne Zusatzspalte in DB.
Delphi-Quellcode:
Obiges funktioniert nicht, das Statement ....Clear ergibt einen Laufzeitfehler.
VAR
data: VARIANT; BEGIN data := .. Daten von einem EXCEL-Feld holen (ok) (* Typ kann variieren, je nach Eingabe: - richtige Datumseingabe - Feld leer lassen - Falsche Eingabe, z.B. ??? *) .. (* Faelle Feld = empty und richtige Datumseingabe bearbeiten *) IF VarType(data) = varEmpty THEN ImportKredFilesForm.ADOQuery1['RechungsDatum'].Clear ELSE ImportKredFilesForm.ADOQuery1['RechungsDatum'] := data; (* Die Spalte 'RechnungsDatum' ist in der ACCESS-DB als DateTime (Datum/Uhrzeit) definiert, kein Default-Wert *) 'Ungültige Variantenoperation' aufgetreten. Ich hoffe ihr habt da Ideen. Ich werde sicher irgendwann den Typ VARIANT mal genauer studieren, aber möglichst nicht jetzt. Danke für Lösungsansätze. |
AW: DateTime über ParamByName auf NULL setzen?
eventuell
Delphi-Quellcode:
Aber wenn data leer ist und leer in die DB soll, warum dann nicht leer schreiben?
IF VarType(data) = varEmpty
THEN ImportKredFilesForm.ADOQuery1['RechungsDatum'].AsVariant := EmptyParam ELSE ImportKredFilesForm.ADOQuery1['RechungsDatum'].AsVariant := data;
Delphi-Quellcode:
Für mich ist momentan nicht erkenntlich, warum eine Fallunterscheidung erforderlich sein sollte.
ImportKredFilesForm.ADOQuery1['RechungsDatum'].AsVariant := data;
|
AW: DateTime über ParamByName auf NULL setzen?
Ich gehe eigentlich davon aus, dass der Datentyp der DB-Spalte 'RechnungsDatum' fixiert
ist (DateTime) und daher nur dieses Format akzeptiert. Damit wäre es nicht möglich einen String zuzuweisen. Liege ich da falsch ? |
AW: DateTime über ParamByName auf NULL setzen?
@Delphi.Narium
Entschuldige, ich hab deinen Beitrag etwas unsorgfältig gelesen. Ich werde das später heute Abend genau ansehen. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 07:10 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 by Thomas Breitkreuz