小鹿鹿鹿 2021-12-21 09:09 采纳率: 100%
浏览 93
已结题

SQL语句合并查询两张表

问题遇到的现象和发生背景

想要查询两张表:
表A:
| 名称 | 类型 | 价格
| ------ | ------ | ------
| 包 | 1 | 200
| 包 | 2 | 600
| 口红 |2 | 400
| 粉底液 | 1 | 300
表B:
| 名称 | 价格
| ------| ------
| 包 | 200
| 口红| 300

我想要达到的结果
名称类型价格
1400
2600
口红1300
口红2400
粉底液1300
我的解答思路和尝试过的方法

(表A和表B合起来查询,表B内所有价格都属于1类型,如果表A中有对应名称的类型,则价格相加,如果表A中没有,则直接放入结果)
SQL语句怎么写,哭了!
SELECT A.名称, A.类型,A.价格 as 价格
from A left join B on A.名称 = B.名称
where A.价格 != 0 and B.价格 != 0 and A.类型 = 1 group by A.名称
目前只想打这个SQL语句,查询结果是:
| 名称 | 类型 | 价格
| ------ | ------ | ------
| 包 | 1 | 400
求SQL能人指点迷津!不甚感激。

  • 写回答

3条回答 默认 最新

  • Kyle_Ping 2021-12-21 09:42
    关注

    先将两张表合并成一张表,然后再分组求和

    select 名称,类型,sum(价格)
    from (
        select A.名称 as 名称,A.类型 as 类型,A.价格 as 价格
        from A
        union all
        select B.名称 as 名称,1 as 类型,B.价格 as 价格
        from B
    )
    group by 名称,类型
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 12月29日
  • 已采纳回答 12月21日
  • 创建了问题 12月21日