![]() |
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? |
Re: Insert über 2 Tabellen (join?)
Hallo,
nein, zuerst Master-Tabelle den Record rein, den PrimaryKey "holen", also den gerade angelegten, wie holen ? keine Ahnung, musst wie schon geschrieben, mal suchen. Diesen PrimKey der Mastertabelle nimmst du als Foreign Key in deiner Detail-Tabelle und trägst dort jetzt die Details ein. Heiko |
Re: Insert über 2 Tabellen (join?)
Wird der Primärschlüssel aus tblPruefung
als Fremdschlüssel der tblKalibrierung eingetragen? |
Re: Insert über 2 Tabellen (join?)
Zitat:
Master-Tabelle ist tblKalibrierung Detail-Tabelle ist tblPruefung |
Re: Insert über 2 Tabellen (join?)
-------------------
Also nochmal langsam, ich habe ja 2 Tabellen, eigentlich habe ich eine 1:1 Beziehung. Da eine Prüfung genau eine Kalbrierung hat und 1 Kalibrierung definitiv zu einer Prüfung gehört, wollte es für die bessere Übersicht in 2 Tabellen packen... |
Re: Insert über 2 Tabellen (join?)
Hallo,
mal ohne eine Tabellen Tabelle Personal: Personal.Id, Personal.Name, Personal.PersonalGruppeId Tabelle PersonenGruppe: PersonenGruppe.PersonenGruppeId, PersonenGruppe.Name 1. Personal.PersonalGruppeId wird referenziert auf PersonenGruppe.PersonenGruppeId, ist also eine Foreign Key, 2. es kann kein Wert für Personal.PersonalGruppeId angeöegt werden, der nicht in der Tabelle PersonenGruppe schon drinsteht. Auf deinen Fall umgesetzt, willst du eine neue Person mit neuer Personengruppe anlegen. Dazu muss zuerst eine Personengruppe angelegt werden (siehe 2.) Diese neue Personengruppe-Id trägst DU beim Anlegen der neuen Person ein. Heiko |
Re: Insert über 2 Tabellen (join?)
@Heiko,
Hi, ja genau so ist es denke richtig, danke dir werde es so machen, d.h: Ich lege eine Kalbrierdatensatz im tblKalibrierung an, merke mir die ID und lege die ID in tblPruefung als Fremdschlüssel ab :-D :-D BINGO Gracias |
Alle Zeitangaben in WEZ +1. Es ist jetzt 01:26 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