AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Dataset (Master-Detail)
Thema durchsuchen
Ansicht
Themen-Optionen

Dataset (Master-Detail)

Ein Thema von nachti1505 · begonnen am 27. Nov 2008 · letzter Beitrag vom 27. Nov 2008
Antwort Antwort
Benutzerbild von nachti1505
nachti1505

Registriert seit: 7. Apr 2007
188 Beiträge
 
Delphi 7 Enterprise
 
#1

Dataset (Master-Detail)

  Alt 27. Nov 2008, 14:54
Datenbank: Firebird • Version: 2.1 • Zugriff über: FIBPlus
Hallo!

Habe zwei Tabellen, welche in der DB mittels ForeignKey verlinkt sind. Auf diese wird aus Delphi mit FIBPlus zugegriffen. Master-Detail-Properties sind gesetzt.

Prinzipiell kann es nun zu folgendem Workflow kommen:

Code:
MasterSet.Insert (neuen Datensatz anlegen und bearbeiten)
MasterSet.TrageEinigeWerteEin
  DetailSet.Insert
  DetailSet.TrageEinigeWerteEin
  DetailSet.Post <-- ERROR!
MasterSet.Post
An besagter Stelle kommt ein Fehler (Referentielle Integrität verletzt), der mir auch vollkommen klar ist. Frage daher, wie sollte man den workflow designen um den Fehler zu vermeiden?

Edith fällt gerade noch ein, dass es in einige Situation hilfreich ist, das DetailSet auf CachedUpdates zu stellen und die Änderungen erst nach MasterSet.Post an die DB zu übertragen. Allerdings sollte in der aktuellen Situation auf CachedUpdates verzichtet werden.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Dataset (Master-Detail)

  Alt 27. Nov 2008, 15:24
Befinden sich beide DataSets in der selben Transaktion?
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von nachti1505
nachti1505

Registriert seit: 7. Apr 2007
188 Beiträge
 
Delphi 7 Enterprise
 
#3

Re: Dataset (Master-Detail)

  Alt 27. Nov 2008, 17:01
Jupp, befinden sie sich...
  Mit Zitat antworten Zitat
alex517

Registriert seit: 23. Nov 2004
Ort: Bernau b. Berlin
273 Beiträge
 
Delphi XE5 Enterprise
 
#4

Re: Dataset (Master-Detail)

  Alt 27. Nov 2008, 21:26
Hi,

Du hast einen ForeignKey vom Slave auf den Master.
Der Fehler entsteht bei dem Versuch einen Slave-Datensatz zu speichern, bevor der ein Master-Datensatz existiert.
Firebird muss ein Masterdatensatz mit der neuen Master-ID bekannt sein bevor in einem Slave-Datensatz eine Referenz
darauf gesetzt werden kann.
Du musst erst ein Master.Post ausführen bevor du ein Slave.Post machen kannst.

Dabei ist zu beachten, dass der die ID (Master.PrimaryKey) auch in der lokalen Datenmenge des FibDataSets
eingetragen wird und damit auch für den Slave-DataSet zu Verfügung steht.

Das kann über 3 Wege erfolgen:
1: Properties FibDataSets.AutoUpdateOptions(GeneratorName, WhenGetGenID, UpdateTableName, Keyfields) setzen
2: im ID mit Gen_ID() im OnNewRecord-Event zuweisen
3: ab FB 2.0 mit INSERT INTO ... VALUES (...) RETURNING .., habe ich aber noch nicht verwendet

alex
Alexander
  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 10:03 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