Delphi-PRAXiS

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?

hoika 31. Jul 2007 14:20

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

DelphiManiac 31. Jul 2007 14:52

Re: Insert über 2 Tabellen (join?)
 
Wird der Primärschlüssel aus tblPruefung
als Fremdschlüssel der tblKalibrierung eingetragen?

shmia 31. Jul 2007 15:08

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

Zitat von DelphiManiac
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?

Achtung!! Was ich oben zu Master- und Detail-Tabelle gesagt habe stimmt so nicht! :?
Master-Tabelle ist tblKalibrierung
Detail-Tabelle ist tblPruefung

DelphiManiac 31. Jul 2007 15:14

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...

hoika 1. Aug 2007 07:25

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

DelphiManiac 1. Aug 2007 09:13

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 12:19 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