V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
zealinux
V2EX  ›  问与答

求一条简单的 sql,一条 sql 两次并行 inner-join?

  •  
  •   zealinux · 2022-05-19 15:35:09 +08:00 · 737 次点击
    这是一个创建于 920 天前的主题,其中的信息可能已经有所发展或是发生改变。
    有两张表,表 A ,表 B ( goods )

    1. 表 A 有两个字段:
    a_goods_id ,b_goods_id

    两个都对应了表 B 的主键 id 字段

    2. 表 B ( goods )里有 name 字段


    问:能不能一条 SQL 命令查出 a_goods_name, b_goods_name ?


    如果只查出一个,我会写下面的

    ``` sql
    SELECT
    name a_goods_name
    FROM
    goods AS B
    INNER JOIN B ON B.id = A.a_goods_id
    WHERE
    B.id = A.a_goods_id;
    ```

    数据库:Postgresql
    5 条回复    2022-05-21 12:04:05 +08:00
    sorcerer
        1
    sorcerer  
       2022-05-19 16:20:49 +08:00 via iPhone
    这。。第一反应不是 join 两次就好了?
    zealinux
        2
    zealinux  
    OP
       2022-05-19 16:55:08 +08:00
    @sorcerer 肯定不行,又不是三表关联联查询。
    AlkTTT
        3
    AlkTTT  
       2022-05-19 17:46:10 +08:00
    union all 呗
    zealinux
        4
    zealinux  
    OP
       2022-05-19 18:50:16 +08:00
    @AlkTTT

    结果是两列 ( a_goods_name, b_goods_name )
    那不能用 union all
    zbinlin
        5
    zbinlin  
       2022-05-21 12:04:05 +08:00
    可以 join 两次表 B:
    SELECT B1.name AS a_goods_name, B2.name AS b_goods_name FROM A INNER JOIN goods AS B1 ON A.a_goods_id = B1.id INNER JOIN goods AS B2 ON A.b_goods_id = B2.id;

    或者使用 subquery:
    SELECT (SELECT name FROM goods WHERE goods.id = A.a_goods_id) AS a_goods_name, (SELECT name FROM goods WHERE goods.id = A.b_goods_id) AS b_goods_name FROM A;
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2888 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 35ms · UTC 08:57 · PVG 16:57 · LAX 00:57 · JFK 03:57
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.