我有这张桌子:
video_id tag_id
10 7
6 7
10 5
6 5
9 5
9 4
10 4
我想写一个查询,它会给我video_id
同时有tag_id
7 和 5。所以video_id
应该选择 10 和 6,而不是 9。
我尝试where tag_id IN (7, 5)
了条件,但显然这包括 9。
它对你有用吗?
SELECT video_id
FROM table1
WHERE tag_id iN (7,5)
GROUP BY video_id
HAVING COUNT(DISTINCT tag_id) =2;
更新。如果您对 (video_id,tag_id) 有唯一约束,则不需要COUNT(DISTINCT)
; COUNT(*)
也会起作用
任意解决方案 -
下面是 sql server 的答案,对于 mysql,您需要在 video_id 上使用 count(),然后查找具有所需值的行。
我没有要测试的 mysql,但可以随意添加正确 mysql 解决方案的编辑。
使用一个名为 requiredtag 的表,其中有一列(标签),其中包含您想要的列表
SELECT video_id
FROM
(
SELECT video_id,
row_number() OVER (PARTITION BY vidio_id ORDER BY video_ID) as RN
FROM table
JOIN neededtag ON tag_id = tag
) sub
WHERE RN = (SELECT COUNT(*) FROM neededtag)
或者您需要的标签可能有一个criteraname 列......然后它看起来像这样:
SELECT video_id
FROM
(
SELECT video_id,
row_number() OVER (PARTITION BY vidio_id ORDER BY video_ID) as RN
FROM table
JOIN neededtag ON tag_id = tag and criteraname = "friday tag list"
) sub
WHERE RN = (SELECT COUNT(*) FROM neededtag WHERE criteraname = "friday tag list")
先前的回答
SELECT video_id
FROM table
WHERE tag_id = 5
INTERSECT
SELECT video_id
FROM table
WHERE tag_id = 7
或者
SELECT video_id
FROM table
WHERE tag_id = 5
AND video_id IN
(
SELECT video_id
FROM table
WHERE tag_id = 7
)
或者
SELECT v1.video_id
FROM table v1
JOIN table v2 WHERE v1.video_id = v2.video_id AND v2.tag_id = 7
WHERE tag_id = 5
可能有更快的方法来做到这一点,但这很简单。我假设有一个带有主键 video_id 的视频表,所以我不必选择 DISTINCT。
SELECT v.video_id FROM videos as v WHERE
EXISTS (SELECT * FROM tagtable as t WHERE t.video_id = v.video_id and tag_id = 7)
AND EXISTS (SELECT * FROM tagtable as t WHERE t.video_id = v.video_id and tag_id = 5)