V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Hanggi
V2EX  ›  程序员

SQL 语句求助,如果通过关联子表找到父表?

  •  
  •   Hanggi · 2020-03-19 14:02:34 +08:00 · 1420 次点击
    这是一个创建于 1705 天前的主题,其中的信息可能已经有所发展或是发生改变。

    简化说明一下需求:

    三个表,有个房间表,还有一个用户表 房间里面有参与者,通过一个关联表连接用户表。 (当然同一个用户可以参加多个房间)

    所以可以很容易地从一个房间里获取到房间里参与的用户。

    现在知道有用户 A 和用户 B。 想找到这两个用户同时参与的房间,要怎么写 SQL 语句呢?

    谢谢

    3 条回复    2020-03-19 15:20:24 +08:00
    Uyuhz
        1
    Uyuhz  
       2020-03-19 14:15:34 +08:00   ❤️ 1
    SELECT room_id FROM 关系表 WHERE user_id IN (a, b) GROUP BY room_id HAVING count(room_id) > 1
    试一下?
    CRVV
        2
    CRVV  
       2020-03-19 14:48:02 +08:00   ❤️ 1
    select a.user_id as a_id, b.user_id as b_id, a.room_id from 关系表 as a inner join 关系表 as b on a.room_id = b.room_id where a.user_id = 'a' and b.user_id = 'b'
    Hanggi
        3
    Hanggi  
    OP
       2020-03-19 15:20:24 +08:00
    @Uyuhz
    @CRVV
    都试过了,结果是正确的。
    感谢🙏🙏🙏
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5603 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 30ms · UTC 08:44 · PVG 16:44 · LAX 00:44 · JFK 03:44
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.