AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Prism Insert der Interbase Datenbank will nicht
Thema durchsuchen
Ansicht
Themen-Optionen

Insert der Interbase Datenbank will nicht

Ein Thema von DeadMatt · begonnen am 15. Jan 2007 · letzter Beitrag vom 15. Jan 2007
Antwort Antwort
DeadMatt

Registriert seit: 11. Jan 2007
32 Beiträge
 
#1

Insert der Interbase Datenbank will nicht

  Alt 15. Jan 2007, 08:55
Datenbank: Interbase • Version: 7.5 • Zugriff über: ADO
Ich hatte schonmal etwas wegen der DB gefragt wo das Update nicht funktioniert hatte doch diesesmal haenge ich beim Insert.... das muesste doch genauso funktionieren oder? hier meine Funktion:
Delphi-Quellcode:
function thisInsert(VORNAME, NACHNAME: string):boolean;
var
  s_sql, Constr, ConOptions: string;
  cmd: BdpCommand;
  trsa: BdpTransaction;
  DBCon: BdpConnection;
begin
  //Einstellungen der Datenbank sowie auch bei ConOptions
  ConStr := 'Provider=Interbase;' +
      'assembly=Borland.Data.Interbase, Version=2.5.0.0,' +
      'Culture=neutral, PublicKeyToken=91d62ebb5b0d1b1b;'  +
      'vendorclient=gds32.dll;pooling=True;' +
      'grow on demand=True;database=localhost:C:\InterbaseDB\TERMINE.IB;' +
      'username=sysdba;max pool size=100;password=masterkey';

  ConOptions := 'LoginPrompt=False;SQLDialect=3;RoleName=None;' +
       'CommitRetain=true;ServerCharSet=NONE;RollbackRetain=False;' +
       'TxnIsolation=ReadCommitted;WaitOnLocks=true';

  //Einstellungen in die Verbindung implementieren
  DBCon:= BdpConnection.Create(ConStr);
  DBCon.ConnectionOptions:= ConOptions;

  s_sql := 'INSERT INTO MITARBEITER (VORNAME, NACHNAME) VALUES ( '''+VORNAME+''', '''+NACHNAME+''')';
  cmd := BdpCommand.Create(s_sql, DBCon);
  
  try
    DBCon.Open;
          trsa := DBCon.BeginTransaction;
          cmd.Transaction:=trsa;
          cmd.ExecuteNonQuery;
          trsa.Commit;
    DBCon.Close;
    result := true;
  except
    result := false;
  end;

end;
woran koennte das liegen?
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.851 Beiträge
 
Delphi 11 Alexandria
 
#2

Re: Insert der Interbase Datenbank will nicht

  Alt 15. Jan 2007, 09:00
Wird ein Fehler angezeigt?
Wie sieht die Tabelle aus (Metadaten)?
Markus Kinzler
  Mit Zitat antworten Zitat
DeadMatt

Registriert seit: 11. Jan 2007
32 Beiträge
 
#3

Re: Insert der Interbase Datenbank will nicht

  Alt 15. Jan 2007, 09:11
der einzige Fehler ist das die Funktion 'false' ausgibt.
In der Tabelle existieren die Spalten ID,VORNAME und NACHNAME mit dem Daten 'Vorname1' und 'Nachname1' ^^'
beide VarChar(25) und die Spalte ID, die einen Generator besitzt, fuer das autoincrement.
sonst noch Informationen die fehlen?
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.851 Beiträge
 
Delphi 11 Alexandria
 
#4

Re: Insert der Interbase Datenbank will nicht

  Alt 15. Jan 2007, 09:15
Deaktiviere mal den Exceptionhandler um den Fehler zu sehen.
Markus Kinzler
  Mit Zitat antworten Zitat
Jürgen Thomas

Registriert seit: 13. Jul 2006
Ort: Berlin
750 Beiträge
 
#5

Re: Insert der Interbase Datenbank will nicht

  Alt 15. Jan 2007, 09:17
Hallo,
ich glaube, ich habe irgendwo gelesen, dass es Probleme gibt, wenn die ID "erst" durch einen Trigger und Generator festgelegt wird, während der Provider deren Existenz als bekannt vorausgesetzt wird. Versuche doch einmal, eine ID vorher zu festzulegen, um das Problem einzugrenzen.

Gruß Jürgen
#D mit C# für NET, dazu Firebird
früher: Delphi 5 Pro, Delphi 2005 Pro mit C# (also NET 1.1)
Bitte nicht sauer sein, wenn ich mich bei Delphi-Schreibweisen verhaue; ich bin inzwischen an C# gewöhnt.
  Mit Zitat antworten Zitat
DeadMatt

Registriert seit: 11. Jan 2007
32 Beiträge
 
#6

Re: Insert der Interbase Datenbank will nicht

  Alt 15. Jan 2007, 09:30
Zitat von mkinzler:
Deaktiviere mal den Exceptionhandler um den Fehler zu sehen.
wo stellt man den aus?^^'*peinlich*

@Jürgen Thomas
ne das isses nich, gerade getestet
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.851 Beiträge
 
Delphi 11 Alexandria
 
#7

Re: Insert der Interbase Datenbank will nicht

  Alt 15. Jan 2007, 09:47
Kommentiere das try und den except-Teil mal su.
Markus Kinzler
  Mit Zitat antworten Zitat
DeadMatt

Registriert seit: 11. Jan 2007
32 Beiträge
 
#8

Re: Insert der Interbase Datenbank will nicht

  Alt 15. Jan 2007, 09:53
Zitat:
Ausnahmedetails: Borland.Data.Common.BdpException: Ausführung misslungen. validation error for column ID, value "*** null ***"

Quellfehler:

Delphi-Quellcode:
Zeile 134: trsa := DBCon.BeginTransaction;
Zeile 135: cmd.Transaction:=trsa;
Zeile 136: cmd.ExecuteNonQuery;
Zeile 137: trsa.Commit;
Zeile 138: DBCon.Close;
das kommt dann raus O.o nu macht die ID also probs
  Mit Zitat antworten Zitat
DeadMatt

Registriert seit: 11. Jan 2007
32 Beiträge
 
#9

Re: Insert der Interbase Datenbank will nicht

  Alt 15. Jan 2007, 10:18
Nu klappts ^^ hatte den Triger wohl nicht ganz richtig^^
  Mit Zitat antworten Zitat
Antwort Antwort


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 16:37 Uhr.
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