Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Transaktion mit AnyDAC auf Oracle-DB (https://www.delphipraxis.net/98438-transaktion-mit-anydac-auf-oracle-db.html)

s.h.a.r.k 27. Aug 2007 14:23

Datenbank: Oracle • Version: 10.x • Zugriff über: AnyDAC (neueste Version)

Transaktion mit AnyDAC auf Oracle-DB
 
Hallo,

ich hoffe, dass mir hierbei jemand helfen kann, da ich langsam am Verzweifeln bin. Ich nutze nun AnyDAC (neueste Version) anstatt ODBC, um auf eine Oracle-Datenbank zuzugreifen.

Eine kleine Vorgangsbeschreibung:
Nun ist es so, dass ich zwei Tabellen habe, die wie folgt aufgebaut sind: eine Spalte aus Tabelle B referenziert eine Spalte aus Tabelle A. Ein Datensatz aus meinem Programm kann aus bis zu 16 Datensätzen in der Datenbank aufgebaut sein. Bitte auf den Unterschied des Begriffs Datensatz achten! Wird nun ein Datensatz in meinem Programm erzeugt wird auf jedenfall ein Datensatz in der DB in Tabelle A und max. 15 Datensätze (jedoch min. einem) in Tabelle B geschrieben. Diese max. 15 Datensätze haben jeweils eine Referenz auf den einen Datensatz in Tablle A. Ich hoffe, dass die Situation soweit klar ist.

Meine Idee das hier zu lösen ist, dass ich es über eine Tansaktion ablaufen lasse und wie folgt den Satz an SQL-Befehlen erstelle:
Zitat:

  • INSERT in Tabelle A
  • INSERT in Tabelle B (max. 15 mal, jedoch min. ein mal)

Ich weiß nur leider nicht wirklich, wie ich das ganze mit AnyDAC verwirkliche. Ich hoffe, dass schon jemand Erfahrungen damit gesammelt hat und mir hierbei weiterhelfen kann.

mfg shark

s.h.a.r.k 29. Aug 2007 14:04

Re: Transaktion mit AnyDAC auf Oracle-DB
 
Hier könnt ihr nachschauen, wie es gemacht werden sollte:


Alle Zeitangaben in WEZ +1. Es ist jetzt 01:58 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