AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken C# Abfrage über mehrere Tabellen mit Einschränkungen
Thema durchsuchen
Ansicht
Themen-Optionen

Abfrage über mehrere Tabellen mit Einschränkungen

Ein Thema von Mithrandir · begonnen am 7. Apr 2012 · letzter Beitrag vom 8. Apr 2012
Antwort Antwort
Benutzerbild von Bummi
Bummi

Registriert seit: 15. Jun 2010
Ort: Augsburg Bayern Süddeutschland
3.470 Beiträge
 
Delphi XE3 Enterprise
 
#1

AW: Abfrage über mehrere Tabellen mit Einschränkungen

  Alt 8. Apr 2012, 08:28
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...
Thomas Wassermann H₂♂
Das Problem steckt meistens zwischen den Ohren
DRY DRY KISS
H₂ (wenn bei meinen Snipplets nichts anderes angegeben ist Lizenz: WTFPL)
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

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

AW: Abfrage über mehrere Tabellen mit Einschränkungen

  Alt 8. Apr 2012, 08:49
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'
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
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#3

AW: Abfrage über mehrere Tabellen mit Einschränkungen

  Alt 8. Apr 2012, 09:49
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.
Gruß, Jo
  Mit Zitat antworten Zitat
Benutzerbild von Bummi
Bummi

Registriert seit: 15. Jun 2010
Ort: Augsburg Bayern Süddeutschland
3.470 Beiträge
 
Delphi XE3 Enterprise
 
#4

AW: Abfrage über mehrere Tabellen mit Einschränkungen

  Alt 8. Apr 2012, 10:53
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')
Thomas Wassermann H₂♂
Das Problem steckt meistens zwischen den Ohren
DRY DRY KISS
H₂ (wenn bei meinen Snipplets nichts anderes angegeben ist Lizenz: WTFPL)
  Mit Zitat antworten Zitat
Antwort Antwort


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 22:41 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-2025 by Thomas Breitkreuz