Einzelnen Beitrag anzeigen

Benutzerbild von GuenterS
GuenterS

Registriert seit: 3. Mai 2004
Ort: Österreich > Bad Vöslau
760 Beiträge
 
Turbo Delphi für Win32
 
#1

DBExpress DateTime Parameter: dbExpress-Fehler:[0x0003]

  Alt 29. Jan 2007, 11:55
Datenbank: MSSQL Server • Version: 2000 • Zugriff über: dbExpress
Hallo!

Ich verwende Delphi7 mit ServicePack1.

Ich versuche in eine Tabelle Datensätze einzutragen und bekomme folgende Fehlermeldung:

Zitat:
dbExpress-Fehler: [0x0003]: Ungültiger Feldtyp.
Um einzugtragen verwende ich folgenden Code:

Delphi-Quellcode:
  InsQry.ParamByName('a').AsInteger := 2;
  InsQry.ParamByName('b').AsString := '2';
  InsQry.ParamByName('c').AsDateTime := now;
  InsQry.ExecSQL;
Parameter a habe ich als Integer, b als String mit Länge 255 und c als DateTime deklariert. Alle Parameter als Input Parameter.

Der SQL String in der InsQry Komponente schaut folgendermassen aus:
Zitat:
INSERT INTO TEST (a, b, c) VALUES (:a, :b, :c)
Wenn ich das letzte Feld (c) nicht setze, also aus dem InsertStatement entferne und damit auch der Parameter weg ist, funktioniert es, sonst nicht. Daher schließe ich daraus, dass es am Datumstyp liegen muss.

Das Feld ist in der Datenbank als datetime definiert.
Günter
Pünktlichkeit ist die Fähigkeit vorherzusagen um wieviel sich der Andere verspäten wird.
  Mit Zitat antworten Zitat