Mysql
 sql >> база данни >  >> RDS >> Mysql

Филтриране от съединителна таблица

JOIN решение:

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 решение:

Имайте предвид, че трябва да изброите всички t.* колони в GROUP BY клауза, освен ако не използвате MySQL или 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;

Решение на подзаявка:

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

Модифициран GROUP BY решение:

Опростява GROUP BY клауза чрез изолиране на търсене в подзаявка.

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. Връзка родител - дете в рамките на една таблица

  2. mysqli_fetch_array грешка дори когато заявката е валидна; изпълнява общи експорти като NULL стойности

  3. Обработка и регулация на връзката с ProxySQL

  4. Премахване на количество от множество редове в база данни

  5. сценарий за проектиране на релационна база данни