Delphi-PRAXiS
Seite 2 von 4     12 34      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Firebird Db Trigger Problem (https://www.delphipraxis.net/171209-firebird-db-trigger-problem.html)

mkinzler 27. Okt 2012 09:56

AW: Firebird Db Trigger Problem
 
Kommt darauf an, ob Zeos RETURNING versteht, wenn ja:

SQL-Code:
insert into <Tabelle> ( ID, <weitere Felder>)
               values ( (select
                            gen_id( GEN_DeineTabelle_ID, 1 )
                         from
                            RDB$Database), <weitere Werte>)
               RETURNING ID;
Sonst als getrennte Abfrage.

Perlsau 27. Okt 2012 19:16

IBExpert
 
Liste der Anhänge anzeigen (Anzahl: 1)
@Privateer3000:

Ich verwende zum Erstellen und Ändern von Firebird-Datenbank immer die Personalversion von IBExpert. Bevor du das Tool herunterlädst, mußt du dich registrieren.

IBExpert bietet beim Erstellen einer Tabelle die Möglichkeit, ein AutoInc-Feld zu definieren, wie in der angehängten Grafik dargestellt. Dabei kann man sich gleich automatisch den entsprechenden Trigger, den Generator und eine Prozedur generieren lassen. Die sehen dann so aus:

Prozedur SP_GEN_PROJEKT_ID
Code:
begin
  ID = gen_id(GEN_PROJEKT_ID, 1);
  suspend;
end

/* DLL */
SET TERM ^ ;

CREATE OR ALTER PROCEDURE SP_GEN_PROJEKT_ID
returns (
    ID integer)
as
begin
  ID = gen_id(GEN_PROJEKT_ID, 1);
  suspend;
end^

SET TERM ; ^

/* Existing privileges on this procedure */

GRANT EXECUTE ON PROCEDURE SP_GEN_PROJEKT_ID TO SYSDBA;
Trigger PROJEKT_BI
Code:
as
begin
  if (new.IDX_PROJEKT is null) then
    new.IDX_PROJEKT = gen_id(GEN_PROJEKT_ID,1);
end

/* DLL */
/******************************************************************************/
/*        Following SET SQL DIALECT is just for the Database Comparer        */
/******************************************************************************/
SET SQL DIALECT 3;

CREATE GENERATOR GEN_PROJEKT_ID;

SET TERM ^ ;

CREATE OR ALTER TRIGGER PROJEKT_BI FOR PROJEKT
ACTIVE BEFORE INSERT POSITION 0
as
begin
  if (new.IDX_PROJEKT is null) then
    new.IDX_PROJEKT = gen_id(GEN_PROJEKT_ID,1);
end
^

SET TERM ; ^
Generator GEN_PROJEKT_ID
Code:
CREATE SEQUENCE GEN_PROJEKT_ID;
ALTER SEQUENCE GEN_PROJEKT_ID RESTART WITH 1;

/* Old syntax is:
CREATE GENERATOR GEN_PROJEKT_ID;
SET GENERATOR GEN_PROJEKT_ID TO 1;
*/

Privateer3000 27. Okt 2012 21:24

AW: Firebird Db Trigger Problem
 
Vielen Dank.
Ich habe mit IBExpert die Trigger ausprobiert
die ich im IBEasy erstellt habe.
Siehe da: sie funktionieren.
Es liegt am IBEasy.
Vielen Dank für den IBExpert Tipp.

Privateer3000 27. Okt 2012 22:49

AW: Firebird Db Trigger Problem
 
By the Way
kann man mit Generatoren auch ein Timestamp realisieren
so das beim DS erstellen ein Timestamp eingetragen wird?
Grüße

PS: Ich weiß offTopic, aber wollte deswegen keinen neuen Thread aufmachen

Perlsau 27. Okt 2012 23:09

AW: Firebird Db Trigger Problem
 
Zitat:

Zitat von Privateer3000 (Beitrag 1188693)
kann man mit Generatoren auch ein Timestamp realisieren

Ja. Das sollte dann aber eher in einen Trigger OnBeforeInsert oder OnBeforeUpdate.

Hansa 27. Okt 2012 23:40

AW: Firebird Db Trigger Problem
 
Zitat:

Zitat von Privateer3000 (Beitrag 1188531)
Aber ist
Code:
select
    gen_id( GEN_DeineTabelle_ID, 1 ) as NeueID
from
  RDB$Database
auch Multiuser tauglich?
Ich werde mit einer Testanwendung erstmal
sehen ob IBEasy nicht triggert oder ob es in der DB ein Problem gibt.
Grüße & Danke

Das ist schon Multiuser-fähig. Aber Generatoren sind nicht Transaktions-fähig ! Hier wurde mal der Tip gegeben, einen Generatoren-Wert zum Hochzählen von Rechnungsnummern zu verwenden, obwohl die lückenlos sein müssen. Da muss aber dann beachtet werden, dass das Finanzamt da ohne weiteres nicht mitspielt.

Denn es gilt : Trigger liegt in der DB. D.h., der schlägt immer zu, egal welches Programm für die DB benutzt wird ! Also eigenes Programm, IBExpert, anderes eigenes Programm oder sonstwas. Eventuell ausser IBEasy. :P

mkinzler 28. Okt 2012 07:59

AW: Firebird Db Trigger Problem
 
Zitat:

By the Way
kann man mit Generatoren auch ein Timestamp realisieren
so das beim DS erstellen ein Timestamp eingetragen wird?
Das würde ich eher durch einen Defaultwert CURRENT_TIMESTAMP bewerkstelligen

Privateer3000 28. Okt 2012 10:11

AW: Firebird Db Trigger Problem
 
Zitat:

Zitat von mkinzler (Beitrag 1188707)
Zitat:

By the Way
kann man mit Generatoren auch ein Timestamp realisieren
so das beim DS erstellen ein Timestamp eingetragen wird?
Das würde ich eher durch einen Defaultwert CURRENT_TIMESTAMP bewerkstelligen

Und wie? Darunter kann ich mir nichts vorstellen.
Direkt in den Generatorwert in dieser Syntax?

Privateer3000 28. Okt 2012 10:17

AW: Firebird Db Trigger Problem
 
Zitat:


Das ist schon Multiuser-fähig. Aber Generatoren sind nicht Transaktions-fähig ! Hier wurde mal der Tip gegeben, einen Generatoren-Wert zum Hochzählen von Rechnungsnummern zu verwenden, obwohl die lückenlos sein müssen. Da muss aber dann beachtet werden, dass das Finanzamt da ohne weiteres nicht mitspielt.

Denn es gilt : Trigger liegt in der DB. D.h., der schlägt immer zu, egal welches Programm für die DB benutzt wird ! Also eigenes Programm, IBExpert, anderes eigenes Programm oder sonstwas. Eventuell ausser IBEasy. :P
Aber im Multiuser MUSS ja sichergestellt sein, dass der nächste Wert auch dem gehört der ihn aufgerufen hat.
Wenn ich nur den Wert hole ohne ihn zu reservieren gehts schief. Oder liege ich da falsch...

mkinzler 28. Okt 2012 10:25

AW: Firebird Db Trigger Problem
 
Zitat:

Und wie? Darunter kann ich mir nichts vorstellen.
Direkt in den Generatorwert in dieser Syntax?
Nein in der Deklaration des Feldes der Tabelle. Für jedes Feld kann man einen Standardwert setzten der dann verwendet wird, wenn dieses beim Post NULL ist. Neben festen Werten gibt es auch Konstanten wie das erwähnte CURRENT_TIMESTAMP, welche immer den aktuellen Zeitwert erhält.
Zitat:

Aber im Multiuser MUSS ja sichergestellt sein, dass der nächste Wert auch dem gehört der ihn aufgerufen hat.
Wenn ich nur den Wert hole ohne ihn zu reservieren gehts schief. Oder liege ich da falsch...
Die Semaphore stellt sicher, dass kein anderer den selben Wert enrhält.Wenn du ihn aber holst ohne zu verwenden (Rollback), dann bleibt der Wert "reserviert". Es entshehen Lücken.


Alle Zeitangaben in WEZ +1. Es ist jetzt 22:22 Uhr.
Seite 2 von 4     12 34      

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