Nochmal eine Datenbankabfrage Frage :-o (JOIN oder so)

Status
Nicht offen für weitere Antworten.

EOB

Top Contributor
hi, also ich komme der sache naeher. ich habe jetzt diese query:


SELECT p.produktnavn, k.knavn, p.beskrivelse FROM produkt p JOIN (produktkategori pk, kategori k) ON (p.id=pk.produktid AND pk.kategoriid=k.id) JOIN (produktfarge pf, farge f) ON (p.id=pf.produktid AND pf.fargeid=f.id) where p.pris LIKE '%foo%' OR p.beskrivelse LIKE '%foo%' OR f.fargenavn LIKE '%foo%' ORDER BY p.produktnavn ASC;


das funzt soweit...denk ich zumindest. habs mit junit getestet und es macht das was ich moechte. jetzt moechte ich allerdings auch noch die tabelle place, brand und dealer durchsuchen. wie muesste ich das obige anpassen, damit er mir auch diese durchsucht und zwar nur, wenn es sich um ein produkt handelt? hier nochmals die skizze der datenbank :).

vielen dank
 

Yzebär

Bekanntes Mitglied
Du hast doch eigentlich schon alles, was du brauchst. Sieh dir doch mal dein Statement genau an. Wenn du Werte einer Tabelle haben willst, machst du ein select from <Tabelle>, wenn du zusätzlich Werte einer verknüpften Tabelle haben willst machst du zusätzlich ein join <AndereTabelle> on <Verknüpfung>. Die Verknüpfung besteht meistens aus einer ID, also Tabelle.AndereTabelleID = AndereTabelle.ID. Wenn du Verknüpfungen über mehrere Tabellen hinweg hast, kommt zu jeder Verknüpfung ein join <WeitereTabelle> on <WeitereVerknüpfung> hinzu. Ich schreibe dir mal dein bisheriges Statement etwas um und füge die Verknüpfung zur Tabelle brand hinzu.
Code:
SELECT p.produktnavn, k.knavn, p.beskrivelse, br.brandname
FROM produkt p 
JOIN produktkategori pk ON p.id=pk.produktid 
JOIN kategori k ON pk.kategoriid=k.id 
JOIN produktfarge pf ON p.id=pf.produktid
JOIN farge f ON pf.fargeid=f.id
JOIN brand br ON p.brandid = br.id
WHERE p.pris LIKE '%foo%' OR p.beskrivelse LIKE '%foo%' OR f.fargenavn LIKE '%foo%' 
ORDER BY p.produktnavn ASC;

Dir Reihenfolge der JOINs ist egal und Ausgangspunkt ist immer die Tabelle nach dem FROM. Tabellen mit mehreren Verknüpfungen müssen nicht für jede Verknüpfung einzeln in einen JOIN gepackt werden, es reicht, wenn jede benötigte Tabelle einmal in einem JOIN steht. So, nun probiere dein Glück mit dealer und place...

Mit welchem Editor bzw. Tool hast du eigentlich das Schema erstellt, das könnte ich vielleicht auch gebrauchen?
 

EOB

Top Contributor
besten dank. allerdings weiss ich nicht, wie ich das mit der tabelle place machen sollte, da die ja nicht so direkt in produkt vorkommt...oder seh ichs nur wieder nicht :roll: . das schema hab ich mit umbrello gemacht, welches unter linux in den sources drinne ist. weiss nicht, obs auch ne windows version gibt. waer cool, wenn du mir das mit place noch sagen koenntest :)

vielen dank erstmal!!

der link zu umbrello :)
 

Yzebär

Bekanntes Mitglied
Bei der Tabelle place ist es so, daß sie ja indirekt mit product verknüpft ist, d.h. du mußt jede Tabelle, die auf dem Weg von product zu place liegt "joinen". Wir machen das mal eben gemeinsam Schritt für Schritt... :wink:
Die erste Verknüpfung auf dem Weg zu place ist dealerproduct, verknüpft über productid.
Code:
SELECT *
FROM product pr
JOIN dealerproduct dpr ON pr.id = dpr.productid
Die nächste Verknüpfung ist von dealerproduct zu dealer...
Code:
SELECT *
FROM product pr
JOIN dealerproduct dpr ON pr.id = dpr.productid
JOIN dealer d ON dpr.dealerid = d.id
Vom dealer kommen wir zum dealerplace...
Code:
SELECT *
FROM product pr
JOIN dealerproduct dpr ON pr.id = dpr.productid
JOIN dealer d ON dpr.dealerid = d.id
JOIN dealerplace dpl ON d.id = dpl.dealerid
Mit einem etwas anderen JOIN kann man auch den dealer überspringen...
Code:
JOIN dealerplace dpl ON dpr.dealerid = dpl.dealerid
Zuletzt müssen wir vom dealerplace zum place... aber den JOIN bekommste jetzt allein hin oder?!
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
T Nochmal Datenbankabfrage Datenbankprogrammierung 6
B Wie kann ich eine Jtable mit Inhalt einer SQL Abfrage füllen Datenbankprogrammierung 14
I SaaS Applikation: pro Kunde eine Datenbank / Schema oder eine DB für alle Kunden? Datenbankprogrammierung 76
Zrebna PostgreSQL-Query in eine MicrosoftSQL-Query konvertieren - chatGPT hilft nur bedingt. Datenbankprogrammierung 3
T Spring MongoDB: Prüfen ob bereits eine Email existiert Datenbankprogrammierung 15
Zrebna Wie mittels Hibernate eine Join-Tabelle als eigene Java-Klasse erstellen? Datenbankprogrammierung 5
Zrebna Probleme bei Überführung von SQL-Code in eine HQL-Abfrage Datenbankprogrammierung 3
Zrebna Wie mittels PL/SQL eine Datenbankverbindung blockieren? Datenbankprogrammierung 6
berserkerdq2 Was genau muss ich bei date eingeben, wenn ich in Java eine Spalte definiere, die date ist? Datenbankprogrammierung 1
pkm PostgreSQL Kann mit mybatis einen Parameter für eine postgreSQL-Abfrage nicht übergeben. Datenbankprogrammierung 5
Kirby.exe Eine Tabelle updaten Datenbankprogrammierung 16
B Wie kopieren ich eine Spalte von einer Tabelle in eine andere Tabelle SQLite durch java code? Datenbankprogrammierung 26
Z Aus zwei bestehenden Table eine zusätzliche Gemeinsame machen (JavaFX) Datenbankprogrammierung 21
Avalon Attribute werden mit Unterstrich in eine MySQL Datenbank eingetragen Datenbankprogrammierung 10
pkm PostgreSQL Auf eine Spalte kann aus einem Teil der SQL-Aussage nicht zugegriffen werden Datenbankprogrammierung 3
F Mapping einer SQL Abfrage in eine Klasse Datenbankprogrammierung 4
H suche eine Login system Bibliothek für Java Datenbankprogrammierung 5
C Datenbank anlegen und über eine Website mit Daten füllen? Datenbankprogrammierung 25
G Eine Spalte in xampp als Typ array erstellen - ein array mit "insert" hinzufügen. Datenbankprogrammierung 3
F Create Table - Habe ich eine schwache Entität erzeugt ? Datenbankprogrammierung 4
Dimax MySQL Trigger für eine Spalte Datenbankprogrammierung 5
Dimax MySQL Maximale Datenlänge für eine Spalte einer Datenbank in java ermitteln Datenbankprogrammierung 15
D MySQL Eibinden des "mysql-connector" in eine fertige Jar Datenbankprogrammierung 3
P JSP - Daten aus 2 Tabellen in eine neue Tabelle einfügen Datenbankprogrammierung 1
P Daten in eine mySQL Datenbank einfügen Datenbankprogrammierung 4
S MySQL JTable zeigt nach Datenbankabfrage eine Spalte zu viel an Datenbankprogrammierung 0
Thallius MySQL Tabelle splitten aber wie eine abfragen? Datenbankprogrammierung 10
B MySQL Eine Art Sverweis Datenbankprogrammierung 27
O HSQLDB Eine Entität, mehrere Tabellen Datenbankprogrammierung 8
B SQL-Statement Prüfen ob eine Spalte einen Wert enthält Datenbankprogrammierung 2
X SQLite Erhalte bei Query INSERT INTO eine NullPointerException Datenbankprogrammierung 10
L0MiN Wie kann ich eine bestimmte Seite aus verschiedenen Excel-Tabellen in eine neue Exceldatei kopieren? Datenbankprogrammierung 1
N Wie in Java Zugriffe und Updates auf eine Datenbank regeln ? Datenbankprogrammierung 1
E Wie kann ich aus diesem XML eine XMLTABLE-Funktion bauen? Datenbankprogrammierung 3
E Wie kann man mit einer ID-Spalte über eine Parameterübergabe auf eine Seite verweisen? Datenbankprogrammierung 17
A Eine MySQL Zeile mit JDBC löschen Datenbankprogrammierung 5
M Warum ist es suboptimal viele Indexe auf eine Datenbanktabelle zu setzen? Datenbankprogrammierung 4
L Datenmodell erstellen für eine Nutzertanalyse Datenbankprogrammierung 1
serjoscha MySQL Eine Instanz von eigenem DBWrapper -> Fehler durch mehrfachbenutzung möglich? Datenbankprogrammierung 2
S HSQLDB Verbieten eines update auf eine bestimmte reihe Datenbankprogrammierung 4
V HSQLDB Insert in eine Tabelle mit Autoincrement Datenbankprogrammierung 2
H Grosse Menge an Daten in eine Datenbank Datenbankprogrammierung 32
P MySQL eine richtige Datenbank für einen routenplaner erstellen Datenbankprogrammierung 2
D SQL Update auf eine Query möglich? Datenbankprogrammierung 4
S SqlObject - eine objektorientierte Art SQL-Statements zu schreiben. Datenbankprogrammierung 4
C Mit jsp über Java eine DB Abfrage durchführen --> java.lang.ClassNotFoundException Datenbankprogrammierung 4
K SQLite CSV-Datei einlesen in eine Datenbank Datenbankprogrammierung 7
E Datenbank Abfragen in eine GUI schreiben Datenbankprogrammierung 8
A Problem mit Eintragen von Daten in eine Datenbank mittels DAO Datenbankprogrammierung 4
L MySQL MySql in eine Application einbinden? Datenbankprogrammierung 18
R MySQL Voraussetzungen für eine erfolgreiche Datenbankanbindung mittels JDBC Datenbankprogrammierung 2
H Derby/JavaDB Eine verschlüsselte Derby-Datenbank wieder entschlüsseln Datenbankprogrammierung 4
D Was passiert bei absolut zeitgleichem Zugriff auf eine Tablerow Datenbankprogrammierung 7
I Belastet es das System zu sehr einen Timer jede 0.2 Sekunden eine DB Abfrage machen zu lassen? Datenbankprogrammierung 9
I Zugriff auf eine Datenbank auf dem Webserver Datenbankprogrammierung 2
F H2:Wie kann man insert eine Reihe "int" wert als blob in table? Datenbankprogrammierung 12
J mal wieder eine Frage zu parallelen Transaktionen.. Datenbankprogrammierung 2
Screen Ich suche eine SQLDatenbank ohne JDBC-Treiber Datenbankprogrammierung 12
H Derby/JavaDB SQLException wenn die Datenbank in eine Jar gepackt wurde. Datenbankprogrammierung 6
turmaline [Hibernate] @OneToMany - Eine referenzierte Tabelle abfragen Datenbankprogrammierung 11
S Werte aus Datenbank auslesen und in eine bestimmte Excelzelle eintragen Datenbankprogrammierung 2
T Wer kann mir eine Datenbank empfehlen Datenbankprogrammierung 13
DStrohma MS SQL Server 2005 + Java: Immer nur eine aktive Verbindung erlaubt? Datenbankprogrammierung 5
D MySQL Wie schreibe ich in eine Datenbank? Datenbankprogrammierung 8
J String[] in eine SQL-Anweisung implementieren Datenbankprogrammierung 13
Q Access Datenbank in eine Internetseite einbinden Datenbankprogrammierung 2
J Über einen Button eine SQL-DB aussuchen Datenbankprogrammierung 3
O eine Tabelle hat mehrere PrimKey mit dem selben Wert Datenbankprogrammierung 9
R Connection Problem für eine externe DB mit Java (JDBC) Datenbankprogrammierung 9
M Zugriff auf eine Access-Datenbank innerhalb eines jar-Files Datenbankprogrammierung 7
N Wie kann ich Zugriff auf eine MS Access DB (mit JDBC) über Netzwerk erreichen? Datenbankprogrammierung 7
G Wie sieht eine Datenbankverbindung mit jndi aus? Datenbankprogrammierung 3
T eine Datenbank updaten Datenbankprogrammierung 6
C Prüfen, ob eine MySQL-Tabelle bereits existiert Datenbankprogrammierung 7
E Wie auf eine MySql Datenbank zugreifen Datenbankprogrammierung 25
D Werte mit java programm in eine Datenbank einlesen Datenbankprogrammierung 7
T JPQL Query für eine Tabellenansicht Datenbankprogrammierung 2
B Wie persistiert man eine Tree-ähnliche Datenbankstruktur? Datenbankprogrammierung 2
M Aus einem Applet eine Datenbankverbindung starten? Datenbankprogrammierung 26
R Datenbankstruktur für eine renn simulation Datenbankprogrammierung 3
H Wie kann ich eine Datenbank Connection aus XML-Datei lesen! Datenbankprogrammierung 2
G Wie baut man eine Anwendung mit DB Zugriff Datenbankprogrammierung 3
S Als Rückgebewert eine Liste von Werten? Datenbankprogrammierung 3
A Auslesen von Werten aus der DB in eine csv-Datei Datenbankprogrammierung 4
O Oracle 11g wirft bei 90 % der installation eine Exception ? Datenbankprogrammierung 5
T Recordsets in eine JTable einlesen mit Netbeans 6.0 Datenbankprogrammierung 2
R Warum kommt eine Exception bei instanceof ? Datenbankprogrammierung 4
M Tabelle von einer Datenbank in eine Andere Datenbankprogrammierung 4
G Inhalt eine Clob Feldes zw. zwei DB's kopieren Datenbankprogrammierung 2
A Einlesen einer csv-Datei in eine H2-Datenbank Datenbankprogrammierung 3
A Kriterium für eine JList neu definieren Datenbankprogrammierung 3
A Probleme beim Schreiben in eine CSV-Datei aus einer H2-DB Datenbankprogrammierung 2
G Import einer csv-Datei in eine H2-Database Datenbankprogrammierung 12
J Warum ist es aufwendig eine Datenbankverbindung herzustellen Datenbankprogrammierung 3
M Mit Java .txt-Datei in eine Datenbank einlesen lassen Datenbankprogrammierung 33
S Zugriff auf eine große Datenmenge von MS Access per JDBC Datenbankprogrammierung 11
S von einer DB auf eine andere Zugreifen. Datenbankprogrammierung 2
W Wann ist eine Telefonnummer atomar ? Datenbankprogrammierung 3
D Dateien in eine OODB abspeichern Datenbankprogrammierung 3
A Eine einzelne Zeile schreibschützen im DataSet Datenbankprogrammierung 13

Ähnliche Java Themen

Neue Themen


Oben