AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

InsertSQL

Ein Thema von fapsons · begonnen am 13. Mär 2007 · letzter Beitrag vom 14. Mär 2007
Antwort Antwort
Seite 1 von 2  1 2      
fapsons

Registriert seit: 29. Jan 2007
Ort: Berlin
65 Beiträge
 
#1

InsertSQL

  Alt 13. Mär 2007, 13:02
Datenbank: Firebird • Version: 2.0 • Zugriff über: InterBase - TDataSet
Hallo Leute,

will mit folgender Procedure einen Datensatz in die Datenbank hinzufügen. Irgendwie tut sich nur beim Ausführen der Procedure nichts. Erhalte auch keine Fehlermeldung seitens Delphi.

Könnt ihr mir da weiterhelfen?


Gruß,
-fapsons---


Delphi-Quellcode:
procedure Add_New_Terminal(typ, Bez, Beschr :String);
begin
 with D_DataModule.DataSet do
 begin
   InsertSQL.Clear;
   InsertSQL.Text := 'INSERT INTO terminal (TYP, BEZEICHNUNG, BESCHREIBUNG) VALUES (''' + typ + ''',''' + Bez + ''',''' + Beschr + ''')';
   Open;
   Insert;
   Close;
 end;
end;
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: InsertSQL

  Alt 13. Mär 2007, 13:05
Delphi-Quellcode:
   [s]InsertSQL.Clear;[/s]
   InsertSQL.Text := 'INSERT INTO terminal (TYP, BEZEICHNUNG, BESCHREIBUNG) VALUES (''' + typ + ''',''' + Bez + ''',''' + Beschr + ''')';
   Open;
   Insert;
   Post;
   Close;
Markus Kinzler
  Mit Zitat antworten Zitat
fapsons

Registriert seit: 29. Jan 2007
Ort: Berlin
65 Beiträge
 
#3

Re: InsertSQL

  Alt 13. Mär 2007, 13:33
Super, vielen Dank!

Das einzige, was jetzt noch nicht funzt ist, wenn ich einen Datensatz lösche und dann wieder einen neuen hinzufügen will, sagt er mir, dass keine Primary-ID vergeben werden konnte.

Eine Ahnung, woran es liegen kann?
Wenn ich das Programm dazwischen neustarte, gibt es keine Probleme. Sieht irgendwie so aus, als würde ich die Datenbankverbindung nicht korrekt beenden.

Aber führe immer die Close-Anweisung aus. Gibt es noch eine andere?
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: InsertSQL

  Alt 13. Mär 2007, 13:47
Wie heißt den der Primärschlüssel? Wie vergibst du ihn (Generator? Trigger?)
Markus Kinzler
  Mit Zitat antworten Zitat
fapsons

Registriert seit: 29. Jan 2007
Ort: Berlin
65 Beiträge
 
#5

Re: InsertSQL

  Alt 13. Mär 2007, 14:10
Mit diesem Trigger:

SQL-Code:
AS
BEGIN
  IF (NEW.TMID IS NULL) THEN
    NEW.TMID = GEN_ID(GEN_TERMINAL_ID,1);
END
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: InsertSQL

  Alt 13. Mär 2007, 14:37
Wie sind den die Transkationseinstellungen?
Markus Kinzler
  Mit Zitat antworten Zitat
fapsons

Registriert seit: 29. Jan 2007
Ort: Berlin
65 Beiträge
 
#7

Re: InsertSQL

  Alt 13. Mär 2007, 14:46
Meinst du die Eigenschaften von TTransaction?
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: InsertSQL

  Alt 13. Mär 2007, 14:51
Ja.
Markus Kinzler
  Mit Zitat antworten Zitat
fapsons

Registriert seit: 29. Jan 2007
Ort: Berlin
65 Beiträge
 
#9

Re: InsertSQL

  Alt 13. Mär 2007, 15:25
Transaction:

Active := false;
AutoStopAction := saNone;
DefaultAction := TACommit;
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: InsertSQL

  Alt 13. Mär 2007, 15:59
Aktiviere sie mal.
Markus Kinzler
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 05:14 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