![]() |
Datenbank: MySQL • Version: 5.x • Zugriff über: PHP
SQL WHERE über mehrere Einträge
Hallo.
Ich bastle gerade ein bisschen was mit PHP und MySQL und bin auf folgendes Problem gestoßen: Ich habe eine Tabelle "Posts" mit dem Eintrag "post_id" und noch ein paar anderen Daten. Als zweites habe ich eine Tabelle "Post_Topics" mit den Einträgen "post_id" und "topics_id", über welche jedem Post beliebig viele Themen zugeordnet werden. Nun möchte ich eine Abfrage machen, die mir aus der zweiten Tabelle alle "post_id"-Werte zurückliefert, für die bestimmte "topics_id" Werte gesetzt sind: Ich möchte zum Beispiel alle Posts-Ids haben, die sowohl im Thema "Neuigkeit" (ID: 1) als auch im Thema "Release-Beschreibung" (ID: 4) drin sind. Wie kann ich so etwas mit SQL formulieren? Oder habe ich irgendwo einen Designfehler in meiner Tabellenstruktur und wenn ja, wie kann ich das geschickter Anlegen? Ich habe schon ein bisschen danach gesucht, aber irgendwie haben mir wohl die richtigen Suchbegriffe gefehlt. Vielen Dank schon mal im voraus, ich hoffe meine Frage ist verständlich formuliert. Andreas |
AW: SQL WHERE über mehrere Einträge
SQL-Code:
select
post_id from post_topics where Topics_id in ( 1,4); |
AW: SQL WHERE über mehrere Einträge
Das IN ist natürlich besser, aber rein logisch hättest du es auch selber hinbekommen können
SQL-Code:
da SQL ein = 'ne größere Bindung besitzt, als ein OR (im Gegensatz zu Delphi), sollte wohl auch dieses gehn
select post_id
from post_topics where (Topics_id = 1) or (Topics_id = 4);
SQL-Code:
select post_id
from post_topics where Topics_id = 1 or Topics_id = 4; |
AW: SQL WHERE über mehrere Einträge
Hi!
Wenn ich Post 1 richtig verstehe, würde ich sagen, da muss ein AND statt dem OR hin. Liebe Grüße, Frederic |
AW: SQL WHERE über mehrere Einträge
Zitat:
|
AW: SQL WHERE über mehrere Einträge
Hi!
Argh, natürlich nicht - das war ein Schnellschuss. Aber er wollte ja die Einträge, die in Kategorie 1 UND in Kategorie 4 sind - da müsste dann eine etwas andere Abfrage hin, denke ich. Liebe Grüße, Frederic |
AW: SQL WHERE über mehrere Einträge
Zitat:
aber vom Standpunkt der Topics aus ist das OR schin richtig. |
AW: SQL WHERE über mehrere Einträge
Hallo,
eine Abfrage wie
SQL-Code:
liefert natürlich alle Einträge zurück, die entweder in Thema 1 oder 4 sind. Ich möchte jedoch nur Einträge auswählen, die sowohl Thema 1 als auch Thema 4 zugeordnet ist - also sozusagen die Schnittmenge zwischen allen Einträgen mit 1 als auch allen Einträgen mit 4.
SELECT
`post_id` FROM `Post_Topics` WHERE `topic_id` = 1 OR `topic_id` = 4 Die Verknüpfung mit AND liefert immer Null Zeilen zurück, da jede Zeile ja nur einen "topic_id" Wert hat. Ist das irgendwie mit SQL möglich? Die ganze Zeit habe ich den oben genannten SQL-Code verwendet und das Ergebnis dann weiter mit PHP gefiltert, was mir aber nicht sonderlich "elegant" vorkommt. Trotzdem schon mal Danke für alle Antworten, Andreas |
AW: SQL WHERE über mehrere Einträge
topic_id kann pro Row/Zeile/Eintrag doch nur einen Wert haben und demnach kann dort auch nur jeweils einer der beiden Werte 1 oder 4 drinstehn.
ansonsten müßte man getrennt abfragen ob es einen Eintrag mit
Code:
und nocheinen mit
`post_id` = X AND `topic_id` = 1
Code:
gibt und dann das X ausgeben.
`post_id` = X AND `topic_id` = 4
k.A. wie man das in einer Anfrage kombinieren kann, ohne alle post_id's durchzugehn. Aber eventuell könnte man mit GROUP BY erstmal alle post_id's gruppieren und dann nur die Gruppen ausgeben, wo die topic_id's 1 und 4 enthalten sind. |
AW: SQL WHERE über mehrere Einträge
in Oracle würde ich das so machen:
SQL-Code:
SELECT p.post_id FROM
posts p INNER JOIN post_topics pt1 ON pt1.post_id = p.post_id and pt1.topic_id = 1 INNER JOIN post_topics pt2 ON pt2.post_id = p.post_id and pt2.topic_id = 4 |
AW: SQL WHERE über mehrere Einträge
SQL-Code:
SELECT *
FROM posts p WHERE EXISTS (SELECT * FROM post_topics WHERE post_id = p.post_id AND topic_id = 1) AND EXISTS (SELECT * FROM post_topics WHERE post_id = p.post_id AND topic_id = 4) |
AW: SQL WHERE über mehrere Einträge
Ein join der Tabelle mit sich selbst?
SQL-Code:
select
* from Post_Topics as a, Post_Topics as b where a.topicid=1 and b.topicid=4 and a.postid=b.postid |
AW: SQL WHERE über mehrere Einträge
Da bekommst du eine wilde Kombination von Einträgen, welche nichts miteinander zu tun haben
|
AW: SQL WHERE über mehrere Einträge
Okay, nochmal "Selfjoin" nachgelesen, korrigierte Fassung:
Code:
select post_id from
Post_Topics as a join Post_Topics as b on post_id where a.topic_id = 1 and b.topic_id = 4 |
AW: SQL WHERE über mehrere Einträge
Ohne joins
SQL-Code:
man müsste mal schauen was schnell läuft auf deinen db system.
select
post_id from post_topics where Topics_id in (1,4) group by post_id having count(*)=2 |
AW: SQL WHERE über mehrere Einträge
Hallo,
die Lösung von Generic gefällt mir sehr gut, da sie eigentlich genau dem entspricht, was ich vorher mit meinem PHP Skript gemacht habe: Alle Topic_IDs als Array in ein Array mit Post_Id als Schlüssel einzutragen und dann die Anzahl der Elemente zu zählen. Vielen Dank für die Lösungen, Andreas |
AW: SQL WHERE über mehrere Einträge
Nur der Vollständigkeit halber:
Die Lösung von omata, jfheins (beide) und mir funktionieren auch, allerdings hat die Lösung von generic (unter Oracle 11G) den besseren Ausführungsplan. Die Lösung von generic funktioniert allerding nur sollange es in post_topics keine doppelten Kombination von post_id und topic_id gibt. |
AW: SQL WHERE über mehrere Einträge
in dem Fall kannst du die Menge erst einmal mit distinct in einen inneren Select platt machen, um dann das having auszuführen.
Join in MYSQL sind übrigens immer doof. MYSQL neigt dazu ständig temp.Tabellen anzulegen. -> langsam |
Alle Zeitangaben in WEZ +1. Es ist jetzt 05:06 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