![]() |
Stored Procedure ignoriert DEFAULT
Hi,
in einer Tabelle habe ich ein Feld als
SQL-Code:
deklariert. Das Einfügen von Daten geschieht mittels Stored Procedure. Die schert sich aber nicht um den Default Wert. Ist er nicht explizit angegeben, dann wird NULL eingetragen.
DEFAULT 0
Ist das normal ? Oder was muß man machen, damit der Default-Wert auf jeden Fall berücksichtigt wird ? |
Re: Stored Procedure ignoriert DEFAULT
Was für eine Datenbank verwendest Du denn ? Bei Firebird könnte es so aussehen:
SQL-Code:
Die Spalte nWert in Deiner Tabelle hat die Einstellung default 0, diese Einstellung
create procedure MyProc (
p_wert integer ) as begin insert into MyTable (nWert) values (:p_wert); end wirkt sich aber nur aus wenn Du keinen Wert übergeben hast, z.b. hast Du im INSERT Statement die Spalte gar nicht angegeben. Wenn ein Wert für diese Spalte übergeben wird (auch null is ein Wert) greift die Einstellung default nicht. Definier die Spalte mal mit not null, dann sollte die Procedure auch einen Fehler liefern, wenn Du null-Werte einfügen willst. Gruß, Marcel |
Re: Stored Procedure ignoriert DEFAULT
Zitat:
Ich versuche jetzt noch ein DEFAULT 0 NOT NULL zu setzen, aber dann dürfte Fehler kommen wenn der Wert nicht definiert ist. Oder greift dann erst das DEFAULT ??? |
Re: Stored Procedure ignoriert DEFAULT
Zitat:
Wie sieht denn Deine INSERT-Procedure aus? Ist es so, dass in das Feld (von dieser Procedure) nie Werte eingetragen werden oder gibt es mal Werte, mal keine? Im letzteren (wahrscheinlicheren) Fall musst Du klären, was der Procedure übergeben werden. Wird der Procedure (z.B. von einer Delphi-Komponente) nicht ein NULL-Wert übergeben, wenn "keiner" gemeint ist? Wie sollte die Procedure das dann unterscheiden? Es wäre gut, den Kontext zu kennen, also Tabellenstruktur, INSERT-Procedure, Zugriffsart (Komponenten). MfG Urs |
Re: Stored Procedure ignoriert DEFAULT
Die SP selbst dürfte wohl klar sein. ID_KUNDE und TAGNR sind DB-Felder. 2 Parameter mit gleichem Namen sind in der SP. In Delphi sieht es dann so aus :
Delphi-Quellcode:
Der Effekt ist nun, daß selbst wenn KuNr nicht vorhanden ist und eigentlich der Deafault Wert genommen werden müßte, dann steht in der Table NULL drin.
procedure SchreibeDatei (KuNr: string;t: TDate);
begin // KuNr := '4'; if Trim (KuNr) <> '' then SP.ParamByName('ID_KUNDE').AsInteger := StrToInt (KuNr); SP.ParamByName('TAGNR').AsDate := t; SP.ExecProc; end; end; |
Re: Stored Procedure ignoriert DEFAULT
Es ist wie ich vermutet habe:
Wenn Du dem SP.Param keinen Wert zuweist, gibt die Komponente NULL an die Stored Procedure weiter und diese trägt das dann natürlich auch ein. Ich nehme an, in der Tabelle sollen unter ID_KUNDE keine NULLS vorkommen. Dann solltest Du Folgendes tun: - Feld NOT NULL setzen. entweder: - In SchreibeDatei ergänzen
Delphi-Quellcode:
und/oder:
...
if Trim (KuNr) <> '' then SP.ParamByName('ID_KUNDE').AsInteger := StrToInt (KuNr) else SP.ParamByName('ID_KUNDE').AsInteger := 0; - einen Trigger BEFORE INSERT OR UPDATE definieren mit
SQL-Code:
Der DEFAULT-Wert könnte dann auch wegbleiben.
if (new.id_kunde is null) then new.id_kunde = 0
Der Trigger wäre auf jeden Fall besser um zu gewährleisten, dass immer alles richtig ist (möglichst wenig Verantwortung in die Applikation auslagern). Im Übrigen würde ich - falls das nicht im Original ohnehin der Fall ist - prüfen, ob KuNr wirklich einer Integer entspricht und entsprechend reagieren (so wie es dasteht, kommt dann eine Exception mit einer - für den Anwender - vielleicht kryptischen Meldung). MfG und viel Erfolg Urs |
Re: Stored Procedure ignoriert DEFAULT
Nun denn. Das würde aber bedeuten, daß man die DEFAULT am besten gleich vergisst. Was nützen die denn, wenn man sie definiert und eine SP hebelt alles wieder aus ? Teste es jetzt mit erweitertem Trigger.
P.S.: Daß es ein integer ist, das ist wegen eigener Komponente gewährleistet. Man kann gar keine Buchstaben usw. eingeben. |
Re: Stored Procedure ignoriert DEFAULT
Zitat:
1.) die Daten nicht über eine SP eingefügt werden und 2.) sowohl NULL- als auch DEFAULT-Werte vorkommen dürfen (z.B. ein Fremdschlüssel, der entweder auf einen bestimmten Datensatz zeigt(=irgendeine Zahl) oder auf keinen Datensatz zeigt(=NULL) oder noch nicht definiert/angegeben ist (z.B. -1 für "Noch nicht angegeben"). In einem solchen Fall darf man den Trigger natürlich nicht so schreiben wie ich für Deinen Fall vorgeschlagen habe. Zitat:
MfG Urs |
Re: Stored Procedure ignoriert DEFAULT
Im Original kommt das Trim nicht vor. :mrgreen: Das ist komplett aber zu kompliziert, um es hier zu posten. 8)
|
Re: Stored Procedure ignoriert DEFAULT
Ich würde die Prüfungen direkt in den SP einbauen. Ein Trigger ist zwar eine feine Sache, kostet aber zusätzliche Performance. Wenn Du eh einen SP aufrufst würde ich auch alles in diesem SP machen.
SQL-Code:
Gruß,
create procedure KUNDE_SAVE (
p_id_kunde integer, p_tagnr date ) as begin if(p_id_kunde is null) then p_id_kunde = 0; insert into KUNDE (ID,TAG) values (:p_id_kunde,:p_tagnr); end Marcel |
Alle Zeitangaben in WEZ +1. Es ist jetzt 02:47 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