Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   C# Abfrage über mehrere Tabellen mit Einschränkungen (https://www.delphipraxis.net/167587-abfrage-ueber-mehrere-tabellen-mit-einschraenkungen.html)

Mithrandir 7. Apr 2012 19:27

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

mkinzler 7. Apr 2012 19:32

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';

Bummi 7. Apr 2012 22:27

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');

Mithrandir 7. Apr 2012 23:40

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:
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');
Läuft aber doch recht lange die Abfrage... Mal ein bisschen optimieren. Danke euch.. :stupid:

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

Bummi 8. Apr 2012 08:28

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

DeddyH 8. Apr 2012 08:49

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'

jobo 8. Apr 2012 09:49

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.

Bummi 8. Apr 2012 10:53

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 16:16 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