AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Insert über 2 Tabellen (join?)
Thema durchsuchen
Ansicht
Themen-Optionen

Insert über 2 Tabellen (join?)

Ein Thema von DelphiManiac · begonnen am 30. Jul 2007 · letzter Beitrag vom 1. Aug 2007
Antwort Antwort
Seite 1 von 2  1 2      
DelphiManiac

Registriert seit: 5. Dez 2005
742 Beiträge
 
#1

Insert über 2 Tabellen (join?)

  Alt 30. Jul 2007, 21:44
Datenbank: Access • Version: 2003 • Zugriff über: ADO
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
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#2

Re: Insert über 2 Tabellen (join?)

  Alt 30. Jul 2007, 21:46
In Access wirst du nicht drumrumkommen, das manuell nacheinander auszuführen.
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von 3_of_8
3_of_8

Registriert seit: 22. Mär 2005
Ort: Dingolfing
4.129 Beiträge
 
Turbo Delphi für Win32
 
#3

Re: Insert über 2 Tabellen (join?)

  Alt 30. Jul 2007, 21:51
Ich weiß nicht, ob es in Access sowas auch gibt, aber in MySQL gibts dafür den Befehl mysql_insert_id.
Manuel Eberl
„The trouble with having an open mind, of course, is that people will insist on coming along and trying to put things in it.“
- Terry Pratchett
  Mit Zitat antworten Zitat
DelphiManiac

Registriert seit: 5. Dez 2005
742 Beiträge
 
#4

Re: Insert über 2 Tabellen (join?)

  Alt 31. Jul 2007, 11:59
Was hat es denn dann für einen Sinn,
bei Access Beziehungen zu definieren ???
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.619 Beiträge
 
Delphi 12 Athens
 
#5

Re: Insert über 2 Tabellen (join?)

  Alt 31. Jul 2007, 12:01
Google mal nach "referentieller Integrität", dann weißt Du es.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
DelphiManiac

Registriert seit: 5. Dez 2005
742 Beiträge
 
#6

Re: Insert über 2 Tabellen (join?)

  Alt 31. Jul 2007, 12:10
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?
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#7

Re: Insert über 2 Tabellen (join?)

  Alt 31. Jul 2007, 12:15
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:
SELECT 4mA * 0.001 FROM tblKalibrierung Schwierig für den Parser: ist das 4mA jetzt ein Feld oder ein Syntaxfehler ?
Andreas
  Mit Zitat antworten Zitat
DelphiManiac

Registriert seit: 5. Dez 2005
742 Beiträge
 
#8

Re: Insert über 2 Tabellen (join?)

  Alt 31. Jul 2007, 12:22
@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

Danke schonmal
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.275 Beiträge
 
Delphi 10.4 Sydney
 
#9

Re: Insert über 2 Tabellen (join?)

  Alt 31. Jul 2007, 12:30
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
Heiko
  Mit Zitat antworten Zitat
DelphiManiac

Registriert seit: 5. Dez 2005
742 Beiträge
 
#10

Re: Insert über 2 Tabellen (join?)

  Alt 31. Jul 2007, 14:32
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?
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 10:59 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