![]() |
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 |
Re: Insert über 2 Tabellen (join?)
In Access wirst du nicht drumrumkommen, das manuell nacheinander auszuführen.
|
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.
|
Re: Insert über 2 Tabellen (join?)
Was hat es denn dann für einen Sinn,
bei Access Beziehungen zu definieren ??? |
Re: Insert über 2 Tabellen (join?)
Google mal nach "referentieller Integrität", dann weißt Du es.
|
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? |
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:
Schwierig für den Parser: ist das 4mA jetzt ein Feld oder ein Syntaxfehler ?
SELECT 4mA * 0.001 FROM tblKalibrierung
|
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 |
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 |
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 22:58 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz