Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Insert über 2 Tabellen (join?) (https://www.delphipraxis.net/96775-insert-ueber-2-tabellen-join.html)

DelphiManiac 30. Jul 2007 20:44

Datenbank: Access • Version: 2003 • Zugriff über: ADO

Insert über 2 Tabellen (join?)
 
Hallo,

ich habe 2 Tabellen in meiner Access Datenbank,

die eine hat folgende Tupel:

SQL-Code:
tblPruefung
------------
-PruefungsID(PK) AUTOWERT
-Pruefungsdatum
-KalibrierID


tblKalibrierung
--------------
-KalibrierID (PK)
-0mA
-4mA
-20mA
.....


Nun will ich eine Pruefung über einen Inserteinfügen, der gleichzeitig, die dazugehörigen Kalibrierdaten in die
Tabelle tblKalibrierung einfügt.

Mein(e) Problem/Frage ist wie baue ich mein Insert auf, soll meine Applikation die KalbrierID erzeugen und dann die ID merken
und die ID in die tblKalibrierung + Daten eintragen?

Oder sollte man sich einen Join machen, und auf die neue gejointe Tabelle einen Insert Befehl absenden??

Wie würdet ihr soetwas realisieren?

Danke :-)

Gruß
DelphiManiac

mkinzler 30. Jul 2007 20:46

Re: Insert über 2 Tabellen (join?)
 
In Access wirst du nicht drumrumkommen, das manuell nacheinander auszuführen.

3_of_8 30. Jul 2007 20:51

Re: Insert über 2 Tabellen (join?)
 
Ich weiß nicht, ob es in Access sowas auch gibt, aber in MySQL gibts dafür den Befehl mysql_insert_id.

DelphiManiac 31. Jul 2007 10:59

Re: Insert über 2 Tabellen (join?)
 
Was hat es denn dann für einen Sinn,
bei Access Beziehungen zu definieren ???

DeddyH 31. Jul 2007 11:01

Re: Insert über 2 Tabellen (join?)
 
Google mal nach "referentieller Integrität", dann weißt Du es.

DelphiManiac 31. Jul 2007 11:10

Re: Insert über 2 Tabellen (join?)
 
Nunja

referentielle Integrität,
bedeutet ja nach meinem Verständnis, dass wenn es eine Abhängigkeit von Datensatz A mit Datensatz B gibt, dass wenn
A gelöscht wir B auch keine Daseinsberechtigung mehr hat und mit gelöscht wird um die Integrität zu behalten.

Aber ist das in Access nicht auch auschaltbar, und man(n) kann trotzdem Beziehungen definieren?

shmia 31. Jul 2007 11:15

Re: Insert über 2 Tabellen (join?)
 
Grundsätzlich kann die SQL INSERT Anweisung nur in eine Tabelle einfügen.
Das gibt für alle SQL Datenbanken (also nicht nur für Access)
Du musst also nacheinander zwei INSERT-Anweisungen ausführen; zuerst in tblPruefung (Master-Tabelle) einfügen, dann erst in tblKalibrierung (Detail-Tabelle).

Ausserdem: du solltest deine Feldnamen nicht mit einer Ziffer beginnen lassen, da der SQL-Parser dadurch in die Irre geführt werden könnte.
Beispiel:
SQL-Code:
SELECT 4mA * 0.001 FROM tblKalibrierung
Schwierig für den Parser: ist das 4mA jetzt ein Feld oder ein Syntaxfehler ?

DelphiManiac 31. Jul 2007 11:22

Re: Insert über 2 Tabellen (join?)
 
@shima

meine Feldnamen beginnen auch nicht mit einer Ziffer,
habe sie nur zur Veranschaulichung 4mA, 20mA,
genannt.
In Wirklichkeit heißen sie Cal_4mA, Cal_20mA usw..

Gut wenn ich nun ein Insert auf meine tblPruefung mache, dann muss ich ja den Fremschlüsselwert der der Primary Key von meiner
tblKalibrierung ist mit einfügen, aber welchen Wert nehme ich da?

Angenommen ich habe tblKalbrierung mein ID als Autowert(also fortlaufend) gewählt,

gut und wenn ich nun erst in tblPruefung einfüge, kenne ich ja den fortlaufenden Wert noch nicht von tblKalibrierung

Hoffe ich habe mich nicht zu ungenau ausgedrückt :gruebel:

Danke schonmal

hoika 31. Jul 2007 11:30

Re: Insert über 2 Tabellen (join?)
 
Hallo,

suche in Google nach "Access Autowert",
dann findest du eine Lösung per

select @@identity bla

zum Auslesen des letzten AutoWerts.

Du musst das jetzt nur prüfen,
ob es auch klappt bei deinem Access.


Heiko

DelphiManiac 31. Jul 2007 13:32

Re: Insert über 2 Tabellen (join?)
 
Hi,

heißt das, ich muss erst die Detail Tabelle füllen, und mir dann den PrimaryKey merken,

damit ich dann die Master Tabelle füllen kann um dann den Foreign Key abspeichern zu können?


Alle Zeitangaben in WEZ +1. Es ist jetzt 11:39 Uhr.
Seite 1 von 2  1 2      

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