簡體   English   中英

需要從三個表中查詢MySQL

[英]Need MySQL query from three tables

我有三個表:

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

我的問題是構建查詢的方式是什么。 我加入了前兩個表並需要過濾第三個表,但是我應該使用臨時表還是在查詢中進行查詢?

這是簡單的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

嘗試這種方式:

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       

您可以從折扣中獲取所有行,然后獲取所有項目並查找類別。 如果一個商品沒有折扣(空),您將得到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;

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM