Mysql
 sql >> Baza danych >  >> RDS >> Mysql

Filtrowanie z tabeli łączenia

JOIN rozwiązanie:

SELECT t.*
FROM topics t
 JOIN tags_topics t1 ON (t.id = t1.topicId AND t1.tagId = 1)
 JOIN tags_topics t2 ON (t.id = t2.topicId AND t2.tagId = 2)
 JOIN tags_topics t3 ON (t.id = t3.topicId AND t3.tagId = 3)

GROUP BY rozwiązanie:

Pamiętaj, że musisz wymienić wszystkie t.* kolumny w GROUP BY klauzuli, chyba że używasz MySQL lub SQLite.

SELECT t.*
FROM topics t JOIN tags_topics tt 
  ON (t.id = tt.topicId AND tt.tagId IN (1,2,3))
GROUP BY t.id, ...
HAVING COUNT(*) = 3;

Rozwiązanie podzapytania:

SELECT t.*
FROM topics t
WHERE t.id = ANY (SELECT topicId FROM tags_topics tt WHERE tt.tagId = 1)
  AND t.id = ANY (SELECT topicId FROM tags_topics tt WHERE tt.tagId = 2)
  AND t.id = ANY (SELECT topicId FROM tags_topics tt WHERE tt.tagId = 3);

Zmodyfikowano GROUP BY rozwiązanie:

Upraszcza GROUP BY klauzula izolując wyszukiwanie w podzapytaniu.

SELECT t.*
FROM topics t
WHERE t.id IN (
  SELECT tt.topicId FROM tags_topics tt 
  WHERE tt.tagId IN (1,2,3))
  GROUP BY tt.id HAVING COUNT(*) = 3
);


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Nieprawidłowy format XML — jak tego uniknąć

  2. Jak ustawić zestawienie w mysqli?

  3. PDOException w Connector.php wiersz 47:SQLSTATE[HY000] [1045] Odmowa dostępu dla użytkownika 'hassan'@'localhost' (przy użyciu hasła:TAK)

  4. Jak wyświetlić błędy dla mojego zapytania MySQLi?

  5. Zgrabna dynamiczna groupby