AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Firebird 2.0 und RETURNING
Thema durchsuchen
Ansicht
Themen-Optionen

Firebird 2.0 und RETURNING

Ein Thema von Roland1967 · begonnen am 25. Jan 2008 · letzter Beitrag vom 28. Jan 2008
Antwort Antwort
Roland1967

Registriert seit: 29. Jun 2006
19 Beiträge
 
Delphi XE6 Professional
 
#1

Firebird 2.0 und RETURNING

  Alt 25. Jan 2008, 18:42
Datenbank: Firebird • Version: 2 • Zugriff über: SQL
Ich bin bei Firebird 2 auf die RETURNING-Klausel gestoßen, die die Abfrage des Generator-Wertes eleganter löst.
Doch wie kann ich in Delphi diesen Wert ermitteln? Showmessage zeigt immer 0 an. In der Datenbank stehen die Daten drin.

Hat jemand einen Tipp für mich? Das wäre super.


Zitat:
with DBank.IBC_Anschrift do
begin
Close;
SQL.Clear;
SQL.Add('INSERT INTO anschrift (AUFTRAG, Name_1, Name_2)');
SQL.Add('VALUES (''87777'', ''Schulze'', ''Nummer 2'')');
SQL.Add('RETURNING ID');
ExecSQL;

IntToStr(FieldByName('id').asInteger);
showmessage(inttostr(newid));
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Firebird 2.0 und RETURNING

  Alt 25. Jan 2008, 18:48
  newid := ParamByName('id').Value;
Markus Kinzler
  Mit Zitat antworten Zitat
Roland1967

Registriert seit: 29. Jun 2006
19 Beiträge
 
Delphi XE6 Professional
 
#3

Re: Firebird 2.0 und RETURNING

  Alt 28. Jan 2008, 10:57
Leider hat der Trick nicht funktioniert.
Der Compiler meldet einen Fehler (Parameter ID nicht gefunden).
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.625 Beiträge
 
Delphi 12 Athens
 
#4

Re: Firebird 2.0 und RETURNING

  Alt 28. Jan 2008, 11:00
Nicht ExecSQL, sondern Open verwenden.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Roland1967

Registriert seit: 29. Jun 2006
19 Beiträge
 
Delphi XE6 Professional
 
#5

Re: Firebird 2.0 und RETURNING

  Alt 28. Jan 2008, 11:11
Wie man sich doch stundenlang mit solchen Problemen beschäftigen kann...

Ich habe es hinbekommen. Es lag an den verwendeten Komponenten von crLabs (IBDAC).
Man muß beim Rückgabewert ein RET vor den Feldnamen setzen, statt ID also RET_ID.

Delphi-Quellcode:
 
with DBank.IBC_Anschrift do
begin
  Close;
  SQL.Clear;
  SQL.Add('INSERT INTO anschrift (AUFTRAG, Name_1, Name_2)');
  SQL.Add('VALUES (''87777'', ''Schulze'', ''Nummer 2'')');
  SQL.Add('RETURNING ID');

  ExecSQL;
  NewID:= DBank.IBC_Anschrift.ParamByName('RET_ID').Value;

  ShowMessage(IntToStr(NewID);
end;
@DeddyH Das Open funktioniert aber nicht.

Trotzdem vielen Dank für die Anregungen.
  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 13:55 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