doumei8126 2012-06-07 19:29
浏览 48
已采纳

mySQL查询加入与此匹配的关联表这个或这个

I need a little help. Not sure why I can't make sense of this one.

I have a table for songs, genre and an association between the two.

SONGS
song_id
song_name
active (0,1)

GENRE
genre_id
genre_name (rock,jazz,classical,newage,opera)

ASSOC
song_id
genre_id

I can do a simple search like this...

SELECT s.song_name, s.song_id
FROM (songs s)
LEFT JOIN assoc a ON s.song_id = a.song_id
WHERE s.active = 1
AND a.genre_id = 1

And a multi search like this.

SELECT s.song_name, s.song_id
FROM (songs s)
LEFT JOIN assoc a ON s.song_id = a.song_id
WHERE s.active = 1
AND (a.genre_id = 1 
   OR a.genre_id = 2)

BUT, what if I want to get 1 and 2 OR 3? This does not work.

SELECT s.song_name, s.song_id
FROM (songs s)
LEFT JOIN assoc a ON s.song_id = a.song_id
WHERE s.active = 1
AND a.genre_id = 1
AND (a.genre_id = 2 
   OR a.genre_id = 3)

Thanks in advance for help. I have a feeling I am just looking at this the wrong way.

  • 写回答

3条回答 默认 最新

  • drutjkpsr67393592 2012-06-07 19:36
    关注

    You can perform a self-join:

    SELECT s.song_name, s.song_id
    FROM   songs AS s
      JOIN assoc AS a1 ON a1.song_id = s.song_id AND a1.genre_id = 1
      JOIN assoc AS a2 ON a2.song_id = s.song_id AND a2.genre_id IN (2,3)
    WHERE  s.active = 1
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 孟德尔随机化怎样画共定位分析图
  • ¥18 模拟电路问题解答有偿
  • ¥15 Matlab在app上输入带有矩阵形式的初始条件发生错误
  • ¥15 CST仿真别人的模型结果仿真结果S参数完全不对
  • ¥15 误删注册表文件致win10无法开启
  • ¥15 请问在阿里云服务器中怎么利用数据库制作网站
  • ¥60 ESP32怎么烧录自启动程序
  • ¥50 html2canvas超出滚动条不显示
  • ¥15 java业务性能问题求解(sql,业务设计相关)
  • ¥15 52810 尾椎c三个a 写蓝牙地址