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

请教一个 sql 问题,在线等.

  •  
  •   chaleaochexist · 2018-11-24 09:21:06 +08:00 · 2182 次点击
    这是一个创建于 2191 天前的主题,其中的信息可能已经有所发展或是发生改变。
    书到用时方恨少哈.

    爷爷表
    爸爸表
    儿子表 1
    儿子表 2

    想关联查询所有爷爷.id = 1 的所有子孙数据.

    select * from 爷爷
    left join 爸爸
    on 爷爷.id=爸爸.爷爷_id
    left join 儿子 1
    on 儿子 1.爸爸_id = 爸爸.id
    left join 儿子 2
    on 儿子 2.爸爸_id = 爸爸.id

    这么写没毛病吧?
    8 条回复    2018-11-24 14:44:43 +08:00
    kely
        1
    kely  
       2018-11-24 09:28:20 +08:00
    直接从爸爸表开始查,爸爸表上本身有 爷爷_id。
    petelin
        2
    petelin  
       2018-11-24 09:30:23 +08:00 via iPhone
    from 爷爷查出来的是爷爷吧
    kran
        3
    kran  
       2018-11-24 09:38:54 +08:00 via Android
    写两条 SQL 就完事了啊,干嘛非得塞一条里
    mwiker
        4
    mwiker  
       2018-11-24 09:46:04 +08:00
    select t.* from 儿子 1 t inner join 爸爸 t2 on t.爸爸_id = t2.id and t2.爷爷_id = 1
    union all
    select t.* from 儿子 2 t inner join 爸爸 t2 on t.爸爸_id = t2.id and t2.爷爷_id = 1
    xipushi
        5
    xipushi  
       2018-11-24 10:36:48 +08:00 via iPhone
    Sql 没毛病啊。儿子表为什么有两个?爸爸表爷爷表只有一个?
    JackieMe
        6
    JackieMe  
       2018-11-24 10:48:46 +08:00 via Android
    中文编程指日可待啊
    lsido
        7
    lsido  
       2018-11-24 13:43:15 +08:00 via Android
    秀儿
    cc959798
        8
    cc959798  
       2018-11-24 14:44:43 +08:00
    union all 解决,并且不需要连接爷爷表
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1590 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 28ms · UTC 17:03 · PVG 01:03 · LAX 09:03 · JFK 12:03
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.