![]() |
Datenbank: MySQL • Version: 5 • Zugriff über: MySQL.NET
Abfrage über mehrere Tabellen mit Einschränkungen
Hi,
ich habe gerade einen Knoten im Hirn: Bei einer typischen m:n - Beziehung muss ich aus einer Tabelle bestimmte Sätze herausholen. Ich möchte nun alle die Sätze aus dieser Tabelle kommen, die derselben ID zugeordnet sind. Wie geht das? Es gibt einen Knoten, dieser Knoten hat mehrere Tags. Nun möchte ich, wenn ein Knoten bspw. das Tag "restaurant" hat, alle anderen Tags zu diesem Knoten bekommen, am Besten in einem Statement... Ich kommt grad nicht drauf... |
AW: Abfrage über mehrere Tabellen mit Einschränkungen
Wenn ich das Problem richtig verstanden gabe
SQL-Code:
select
* from knoten k join knotentags z on z.knoten = k.id join tags t on t.id = z.tags where k.id = :id and t.bez = 'restaurant'; |
AW: Abfrage über mehrere Tabellen mit Einschränkungen
In Anlehnung an Markus Schema hätte ich die Frage verstanden wie
Code:
select * from knoten k join knotentags z on z.knoten = k.id join tags t on t.id = z.tags where k.id = :id and Exists (Select * from knotentags z2 join tags t2 where t2.id = z2.tags z2.ID=z.i and t2.bez = 'restaurant'); |
AW: Abfrage über mehrere Tabellen mit Einschränkungen
Hey danke. :)
Ich glaube, wir kommen der ganzen Sache schon näher. Aber ist ":id" nicht ein Parameter? Das MySQL - Workbench kann damit irgendwie nicht viel anfangen. Prinzipiell habe ich es jetzt so, dass das Sub-Select die Node-Ids zurückgibt, denen ein "restaurant" - Tag zugeordnet ist. Aber irgendwie schaffe ich es noch nicht, die Tabelle im übergeordneten Select als Basis zu nutzen. //Edit Doch, geht, ich war zu doof:
Code:
Läuft aber doch recht lange die Abfrage... Mal ein bisschen optimieren. Danke euch.. :stupid:
select * from
osm.nodes k join osm.nodestags z on z.node_id = k.id join osm.tags t on t.id = z.tag_id where k.id = (Select z2.node_id from osm.nodestags z2 join osm.tags t2 where t2.id = z2.tag_id and z2.node_id = z.node_id and t2.v = 'restaurant'); Hm - ohne Limit läuft sie schon seit 10 Minuten. Ich habe in allen Tabellen aber auch eine sechsstellige Anzahl an Einträgen. Evtl. sollte ich woanders ansetzen... |
AW: Abfrage über mehrere Tabellen mit Einschränkungen
Wenn MySQL temporäre Tabellen kennt könntest Du die benötigten ID's über eine Preselect sammeln und darüber die endgültige Menge mit einem Join ziehen...
|
AW: Abfrage über mehrere Tabellen mit Einschränkungen
Ist der Subselect eigentlich nötig? Wenn ich keinen Denkfehler mache, müsste es doch auch so gehen:
SQL-Code:
select
* from osm.nodes k join osm.nodestags z on z.node_id = k.id join osm.tags t on t.id = z.tag_id where t.v = 'restaurant' |
AW: Abfrage über mehrere Tabellen mit Einschränkungen
Mir ist anhand der Beschreibung nicht ganz klar, was alles (welche Tab Inhalte) rauskommen sollen (Das Select * from ... ist nicht sehr aussagekräftig). Die Relationen des "Basisselects" und der gewünschten Ergebnismenge ebenfalls unklar.
@DeddyH: Du könntest Recht haben, aber so einfach ist es offenbar nicht. Ich stell mir einen Baum vor, aus der er alle Geschwister eines bekannten Elements haben möchte... Grundsätzlich: Keine Ahnung vom mySql optimizer, aber der ist sicher auch von Menschen programmiert worden. Also gilt zunächst die Faustregel, das Statement mit der größten Selektivität ist als Hauptstatement anzusiedeln. Den (hoffentlich kleinen) Output ein 2. Mal Joinen mit der eigentlich gewünschten Menge. In dem langsamen Statement sieht es so aus, als ob es umgekehrt läuft: Bau eine Riesenergebnismenge von allen Daten der 3 Tabellen und dann erst filtere bitte gemäß where Bedingung 5 Sätze davon raus. Ist natürlich alles Spekulation ohne Tabellenstruktur, Ausfürungsplan und Indizierung. |
AW: Abfrage über mehrere Tabellen mit Einschränkungen
vielleicht ist das durch MySQL besser optimierbar
Delphi-Quellcode:
select * from
osm.nodes k join osm.nodestags z on z.node_id = k.id join osm.tags t on t.id = z.tag_id where z.node_id in (Select Distinct z2.node_id from osm.nodestags z join osm.tags t2 on t2.id = z2.tag_id where t2.v='restaurant') |
Alle Zeitangaben in WEZ +1. Es ist jetzt 10:37 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