AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Zwei Tabellen verknüfen

Ein Thema von Luckie · begonnen am 14. Nov 2009 · letzter Beitrag vom 14. Nov 2009
Antwort Antwort
Seite 1 von 2  1 2      
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#1

Zwei Tabellen verknüfen

  Alt 14. Nov 2009, 10:03
Datenbank: MySQL • Zugriff über: PHP
Ich habe zwei Tabellen:
Tabelle adressen:
Code:
name
vorname
kategorie_id
Tabelle adr_kategorien:
Code:
id
name
Wenn ich jetzt einen Datensatz abspeichere wird die ID der Kategorie in dem Feld kategorie_id abgelegt.

Jetzt will ich alle Datensätze aus der Tabelle adressen, die einer bestimmten Kategorie entsprechen. Die Kategorie liegt dabei als Text vor und nicht als ID der Tabelle. Was ich im Internet gefunden habe:
Code:
SELECT adressen.*
FROM adressen
INNER JOIN adr_kategorien
WHERE adr_kategorien.name='Geschäftlich'
Das funktioniert leider nicht. Führe ich den Query aus, bekomme ich alle Datensätzen.

Dann versuche ich noch zu einem Datensatz aus der Tabelle adressen die zugehörige Kategorie (Namen) zur KategorieID zu bekommen.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Benutzerbild von arbu man
arbu man

Registriert seit: 3. Nov 2004
Ort: Krefeld
1.108 Beiträge
 
Delphi 7 Professional
 
#2

Re: Zwei Tabellen verknüfen

  Alt 14. Nov 2009, 10:07
Das sollte mit einem einfach join gehen z.b. so
SQL-Code:
select a.* -- oder adressen.*
from adressen a, adr_kategorien k
where a.kategorie_id = k.id and k.name = 'Geschäftlich'
Björn
>> http://bsnx.net <<
Virtual DP Stammtisch v1.0"iw" am 19.09.2007 - ich war dabei!
  Mit Zitat antworten Zitat
Benutzerbild von fkerber
fkerber
(CodeLib-Manager)

Registriert seit: 9. Jul 2003
Ort: Ensdorf
6.723 Beiträge
 
Delphi XE Professional
 
#3

Re: Zwei Tabellen verknüfen

  Alt 14. Nov 2009, 10:11
Hi!

Wenn ich dich richtig verstanden habe, dann versuche mal das:

SQL-Code:
SELECT adressen.*
FROM adressen
JOIN adr_kategorien ON adressen.kategorie_id = adr_kategorien.name
WHERE adr_kategorien.name='Geschäftlich'
Zu deinem zweiten Problem:
Was hast du denn von dem Datensatz aus Adressen? Nur Name und Vorname?


Grüße, Frederic
Frederic Kerber
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Zwei Tabellen verknüfen

  Alt 14. Nov 2009, 10:12
Oder besser in der neueren Syntax als expliziten JOIN
SQL-Code:
SELECT
    a.*
FROM
    adressen
        INNER JOIN adr_kategorien k on k.id a.kategorie_id
WHERE
    adr_kategorien.name='Geschäftlich';
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.540 Beiträge
 
Delphi 11 Alexandria
 
#5

Re: Zwei Tabellen verknüfen

  Alt 14. Nov 2009, 10:20
Aber dann den Alias a nicht vergessen:
SQL-Code:
SELECT
    a.*
FROM
    adressen a
        INNER JOIN adr_kategorien k on k.id a.kategorie_id
WHERE
    adr_kategorien.name='Geschäftlich';
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
mkinzler
(Moderator)

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

Re: Zwei Tabellen verknüfen

  Alt 14. Nov 2009, 10:23
in weiterer Grund gegen C&P
SQL-Code:
SELECT
    a.*
FROM
    adressen a
        INNER JOIN adr_kategorien k on k.id a.kategorie_id
WHERE
    k.name='Geschäftlich';
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.540 Beiträge
 
Delphi 11 Alexandria
 
#7

Re: Zwei Tabellen verknüfen

  Alt 14. Nov 2009, 10:24
wir nähern uns der Lösung ^^
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
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#8

Re: Zwei Tabellen verknüfen

  Alt 14. Nov 2009, 10:26
Also ich habe es jetzt wie arbu man gemacht. Das funktioniert.

Bleibt noch der zweite Query. Also dass er mir den Kategorienamen passend zur ID mit ausgibt zu den anderen Feldern.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.540 Beiträge
 
Delphi 11 Alexandria
 
#9

Re: Zwei Tabellen verknüfen

  Alt 14. Nov 2009, 10:30
Meinst Du so?
SQL-Code:
SELECT
    k.name, a.*
FROM
    adressen a
        INNER JOIN adr_kategorien k on k.id a.kategorie_id
WHERE
    k.name='Geschäftlich';
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
mkinzler
(Moderator)

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

Re: Zwei Tabellen verknüfen

  Alt 14. Nov 2009, 10:30
Einfach Feld mit angeben:
SQL-Code:
SELECT
    a.*,
    k.name
FROM
    adressen a
        INNER JOIN adr_kategorien k on k.id a.kategorie_id
WHERE
    k.name='Geschäftlich';
Markus Kinzler
  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 23: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