需要从三个表中查询MySQL

时间:2018-04-19 08:53:26

标签: mysql

我有三张桌子:

Items:
Id   |Name   | Price    | Cat_Id 
---- |-------|----------------
 1   | Item1 |   50.00  | 1    
 2   | Item2 |   25.20  | 5

Category:  
Id   |Name  | 
---- |------|
 1   | Cat1 |    
 2   | Cat2 |

Discount:  
Id   |Item_Id| Client_Id|Discount 
---- |-------|----------------
 1   |   1   |   1      | 10    
 2   |   1   |   2      | 15
 3   |   2   |   2      | 6

我正在尝试以适当的折扣获得所有商品,这对每个客户都是不同的。在这个例子中,我有Client_Id 1的客户端,它对Item1 / 10 /有折扣,而且他对Item2没有折扣。 结果应如下所示:

Id   |Name   | Price    | Cat | Discount
---- |-------|----------------|----------
 1   | Item1 |   50.00  | Cat1|   10
 2   | Item2 |   25.20  | Cat5|   0

我的问题是构建查询的方式是什么。我加入前两个表并需要过滤第三个,但是我应该使用临时表还是在查询中进行查询?

3 个答案:

答案 0 :(得分:3)

这是简单的SQL查询。

Select Id, Name, Price, Cat, Discount From Items
left join discount on Items.id=discount.Item_Id 
left join category on Items.cat_id=id

输出赞:

Id   |Name   | Price    | Cat | Discount
---- |-------|----------------|----------
 1   | Item1 |   50.00  | Cat1|   10
 2   | Item2 |   25.20  | Cat5|   0

答案 1 :(得分:2)

尝试这种方式:

select di.id,di.Client_Id,it.Name,it.Price,ca.Cat,ifnull(di.Discount,0)
from Discount di
    right join Items it on di.Item_id=it.Id
    left join Category ca on it.Cat_Id=ca.Id
order by di_Id,di.Client_id,It.Name       

您可以从折扣中获取所有行,然后获取所有项目并查找类别。如果某个项目没有折扣(null),则会得到0

答案 2 :(得分:0)

要获得您想要的结果,

以下是查询...

select
     i.id item_id,
     d.id discount_id,
     i.name,
     i.price,
     c.name cat_name,
     d.discount
from items i
left join discount d on i.id = d.item_id
left join category c on i.cat_id = c.id
where d.client_id = 1 or d.client_id is null;
/*where condition added after update as OP required*/

<强>更新

根据OP的评论

select
    i.id item_id,d.id discount_id,
    i.name,i.price,c.name cat_name,d.discount
from discount d
left join items i on i.id = d.item_id
left join category c on i.cat_id = c.id
where d.client_id = 2;