coolair
V2EX  ›  问与答

请教一个 SQL 查询。

  •  
  •   coolair · Jun 3, 2016 · 1972 views
    This topic created in 3634 days ago, the information mentioned may be changed or developed.
    主表 X : id, key_1, key_2, key_3
    表 A : id, x_id(foreign key), a_key_1, a_key_2, a_key_3
    表 B : id, x_id(foreign key), b_key_1, b_key_2, b_key_3, c_key_4
    表 C : id, x_id(foreign key), c_key_1, c_key_2, c_key_3, c_key_4, c_key_5

    如何一条语句,查出如下需要的结果呢?
    key_1, key_2, key3, a_key_1, a_key_2, a_key_3
    key_1, key_2, key3, b_key_1, b_key_2, b_key_3
    key_1, key_2, key3, c_key_1, c_key_2, c_key_3

    还有,我这种建表方式是不是有问题?
    2 replies    2016-06-03 11:05:25 +08:00
    woon
        1
    woon  
       Jun 3, 2016 via Android
    这个的话, 是不是这样连接就行:
    SELECT X.key_1, X.key_2, X.key_3, a.key_1, a.key_2, a.key_3
    FROM X, a
    WHERE a.x_id = X.id

    不是很清楚你的各个属性的含义= =
    shakoon
        2
    shakoon  
       Jun 3, 2016
    同 1 楼,在加两个 union all 把 b 、 c 表用一样的语句加在后面。这样就是一条语句了
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   3138 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 53ms · UTC 13:23 · PVG 21:23 · LAX 06:23 · JFK 09:23
    ♥ Do have faith in what you're doing.