Delphi-PRAXiS
Seite 1 von 5  1 23     Letzte »    

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi ADO Guru gesucht (https://www.delphipraxis.net/173724-ado-guru-gesucht.html)

haentschman 12. Mär 2013 18:43

Datenbank: MSSQL • Version: X • Zugriff über: ADO

ADO Guru gesucht
 
Hallo...

ich bin mit meinem Latein am Ende.

Gegeben:
- Tabelle mit "ID" als Autoinc. (PK) (der Rest ist eher uninteressant)
- gewachsenes Programm was so mit anderen DBMS gut funktioniert

IST:
1. TADOTable
2. Tabelle ist leer
Delphi-Quellcode:
Table.Append;
Table... füllen (außer ID logischerweise)
Table.Post;
Table.Refresh; // hier knallts mit Fehler... sinngemäß "Datensatz wurde geändert oder gelöscht. Die aktuelle Zeile wird gelöscht"
...eigentlich sollte das Post ja die Tabelle aktualisieren. Ich vermute, daß das bei ADO nicht funktioniert. Da auf dem Server die ID existiert und in der Datenmenge nicht und er den PK nicht zuordnen kann. An diversen Stellen konnte ich durch ein Open/Close einen Workaround hinbiegen. An anderen Stellen, wo die ID, nach dem Post, weiterverarbeitet wird geht das nicht, da der Datensatzzeiger dann auf dem ersten steht und nicht auf dem letzten Eingefügten.

Erledigt:
Dann habe ich testweise das DBFramework auf SDAC umgerüstet... keinerlei Fehler ! Leider kann ich die Entscheidung nicht selbst treffen.
Versuche mit den Properties der Connection und der ADOTable... ohne Erfolg.

Bitte:
Welche Tricks verhindern diese bescheuerten Meldungen.

:hi:

sx2008 12. Mär 2013 19:40

AW: ADO Guru gesucht
 
Zitat:

Zitat von haentschman (Beitrag 1207150)
Tabelle mit "ID" als Autoinc. (PK) (der Rest ist eher uninteressant)

Man sollte keine AutoInc-Felder verwenden, wenn man den Wert für weitere Verarbeitung noch benötigt!

Zunächst muss man sich mal klarmachen, dass Tabellen ohne Primärschlüsselfeld nicht sicher sind, weil man einen bestimmten Datensatz nur über das eindeutige PK-Feld ändern oder löschen kann.
Code:
Farbe | Hersteller
blau  | VW
silber | BMW
blau  | VW
grau  | Daimler
In der Beispieltabelle gibt es 2 gleiche Datensätze.
Mit SQL gibt es keine Möglichkeit (!) nur einen dieser beiden Datensätze zu verändern oder nur einen davon zu löschen!

Schlussfolgerung
Tabellen ohne Primärschlüssel sind als "defekt" zu betrachten.

Bei einer Tabelle mit einem AutoInc-Feld als PK entsteht ein Problem:
Wenn mehrere Prozess in die gleiche Tabelle Datensätze einfügen,
wie kann dann ein Prozess herausfinden welcher Datensatz von ihm ist?
Da der Primärschlüssel das einzige sichere Erkennungsmerkmal für einen Datensatz ist, der Prozess aber den PK nicht kennt ist es mathematisch für einen Prozess unmöglich seinen gerade geschriebenen Datensatz wiederzuerkennen.

Schlussfolgerung
Autoinc-Felder darf man nur einsetzen wenn man den PK eines gerade eingefügten Datensatzes nicht benötigt.
Sobald aber der PK in einen anderen Tabelle als Fremdschlüssel benötigt wird ergeben sich Probleme.
Nur weil SDAC keinen Fehler erzeugt bedeutet das nicht, dass alles in Ordnung ist.

Mögliche Auswege:
Beim SQL Server kann man z.B. die Abfrage SELECT @@Identity ausführen um den zuletzt eingefügten PK zu erhalten.

Manchmal muss man etwas nachhelfen und das Property TField.AutoGenerateValue im Code einstellen
http://docs.embarcadero.com/products...rateValue.html

Uwe Raabe 12. Mär 2013 20:07

AW: ADO Guru gesucht
 
Zitat:

Zitat von sx2008 (Beitrag 1207156)
Mögliche Auswege:
Beim SQL Server kann man z.B. die Abfrage SELECT @@Identity ausführen um den zuletzt eingefügten PK zu erhalten.

Alternativ kann man auch die OUTPUT-Klausel verwenden:http://msdn.microsoft.com/de-de/libr...CaptureResults

Bernhard Geyer 12. Mär 2013 22:21

AW: ADO Guru gesucht
 
Zitat:

Zitat von sx2008 (Beitrag 1207156)
Mögliche Auswege:
Beim SQL Server kann man z.B. die Abfrage SELECT @@Identity ausführen um den zuletzt eingefügten PK zu erhalten.

Die Abfrage von @@Identity ist nicht sicher wenn man mit Replikationen arbeitet. Wird auch in der MSDN beschrieben was man machen muss um Replikationssicher zu werden.

haentschman 13. Mär 2013 06:42

AW: ADO Guru gesucht
 
Guten Morgen... :-D

...danke für eure Anteilnahme. Die Autoinc ID ist auch primary Key. Ich dachte bisher immer, daß eine Table den Inhalt der Datenbanktabelle repräsentiert. (incl. des Autoinc nach dem Post). Das scheint bei ADO nicht so zu sein.
Leider bin ich auf die Tables festgelegt, ob mir das gefällt oder nicht.
Noch ein Beispiel was in anderen DBMS funktioniert:
Delphi-Quellcode:
Table.Append;
Table.Post; // um die ID zu kriegen ... die Table sollte dann aktuell sein, normalerweise.
Table.Edit; // dann knallts hier...
Table... füllen (außer ID logischerweise)
... ich würde lieber heute als morgen diesen Kram über Bord werfen... leider wäre dafür der Aufwand zu hoch. :roll:

Uwe Raabe 13. Mär 2013 07:21

AW: ADO Guru gesucht
 
Wenn der ID ein AutoIncrement und als aktiver Index eingestellt ist, müsstest du nach dem
Delphi-Quellcode:
Post
mit einem
Delphi-Quellcode:
Refresh; Last;
zum Ziel kommen.

jobo 13. Mär 2013 07:46

AW: ADO Guru gesucht
 
Das Prinzip sollte schon auch unter ADO funktionieren, selbst wenn es die bereits genannten Probleme gibt. Zumindest tut es das bei mir unter Oracle. Hier wird zwar mit Trigger/Sequence der PK generiert, aber das sollte clientseitig egal sein.
Ich würde mal klären, welche Versionen du für ADO > MDAC und in Delphi verwendest.
Die MDAC Version ist je nach Systemaufbau ein Zufallsprodukt der Office Version, unter Delphi gab es immer wieder auch Updates zu ADO.
TADOTable bietet leider auch den geringsten Spielraum. Per Query kannst Du die explizite Rückgabe des PK anfordern und und und...

Bernhard Geyer 13. Mär 2013 08:05

AW: ADO Guru gesucht
 
Zitat:

Zitat von jobo (Beitrag 1207184)
Die MDAC Version ist je nach Systemaufbau ein Zufallsprodukt der Office Version, ...

MDAC nicht. Das wird ganz normal per Windows-Update verteilt. Was du meinst ist die JET-Engine. Diese ist aber schon seit Jahren kein Bestandteil von MDAC mehr.
MDAC ist mittlerweile praktisch nur noch zur Verteilung des ADO/OLEDB, Native Clients für den MS SQL-Server zuständig.

generic 13. Mär 2013 08:39

AW: ADO Guru gesucht
 
Was für ein Cursortyp/CursorLocation/Locktyp ist eingestellt?

Ich mach das in der Regel so wie du das beschreibst.
Code:
TADODataset
CursorLocation:=clUseServer;
.open
.Append
.Post
id := .fieldbyname('id').asinteger;
.close
Bei mir läuft ein MSSQL 2000 oder 2008r2.
Ich nutze die ADO Komponenten welche bei D2007 dabei sind.

Wenn ich mich recht erinnere, stehen die restlichen Werte auf den voreingestellten Werten.

jobo 13. Mär 2013 08:47

AW: ADO Guru gesucht
 
@MDAC:
Ok, ich bin nicht mehr auf dem neuesten Stand. Ab Vista scheinbar automatisch an Bord als WDAC.
Welches OS vorliegt, ist ja nicht angegeben oder?


Alle Zeitangaben in WEZ +1. Es ist jetzt 04:08 Uhr.
Seite 1 von 5  1 23     Letzte »    

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