2017-09-15 19 views
1

私はSQLで在庫を計算しようとしています。私は3つのテーブル製品、購入と販売をしています。 製品のテーブルには、今の色テーブル在庫計算の合計桁

+----+------------------+ 
| id | color_name  | 
+----+------------------+ 
| 1 | dark   | 
|----|------------------| 
| 2 | light   | 
+----|------------------+ 

購入テーブルが

+-------+-------------+ 
| id | quantity |color 
+-------+-------------+ 
| 1 | 15  |dark 
+-------+-------------+ 
| 1 | 10  |light 
+-------+-------------+ 
| 2 | 5   |dark 
+-------+-------------+ 
| 3 | 25  |light 
+-------+-------------+ 

と売上表である

+-------+-------------+ 
| id | quantity |color 
+-------+-------------+ 
| 1 | 5   |dark 
+-------+-------------+ 
| 1 | 5   |light 
+-------+-------------+ 
| 2 | 5   |dark 
+-------+-------------+ 
| 3 | 5   |light 
+-------+-------------+ 

購入と販売テーブルは外部キーIDを持っている

+----+------------------+ 
| id | product_name  | 
+----+------------------+ 
| 1 | apple   | 
|----|------------------| 
| 2 |banana   | 
|----|------------------| 
| 3 |mango    | 
+----+------------------+ 

です参照する製品表のIDを示します。今、私はあなたが探しているかもしれ

+----+------------------+-------------+ 
| id | product_name  | quantity |color 
+----+------------------+-------------+ 
| 1 | apple   | 10  |dark 
|----|------------------|-------------| 
| 1 | apple   | 5  |light 
|----|------------------|-------------| 
| 2 |banana   | 0  |dark 
|----|------------------|-------------| 
| 3 |mango    | 20  |light 
+----+------------------+-------------+ 

答えて

2

あまりにも色に基づいて形式以下での購入と販売の株式利用できる、すなわち差を計算しようとしていますこの

SELECT p.id,p.Name,Purchase.purchaseQty-sales.salseQty as totalQty 
FROM Product p 
OUTER APPLY(
     SELECT purchase.id, SUM(purchase.quantity) purchaseQty 
     FROM purchase 
     where purchase.id= p.id 
     GROUP BY purchase.id 
)Purchase 
OUTER APPLY(
     SELECT sales.id, SUM(sales.quantity) salseQty 
     FROM sales 
     where sales.id= p.id 
     GROUP BY sales.id 
)sales 
+0

私たちは別のテーブルの色を持っている場合は、アップルの赤い色とリンゴの光の赤と –

+0

私はあなたのためにそれをチェックすることができます –

0
SELECT a.id, a.product_name, 
SUM(b.quantity) - SUM(c.quantity) as 'quantity' 
FROM product a 
LEFT JOIN purchase b 
ON a.id=b.id 
LEFT JOIN sales c 
ON b.id = c.id group by a.id, a.product_name 

(私は何をテストしていない)

+0

特定の製品の販売実績がない場合はどうなりますか?それを解決する方法が提供されていない場合はnullになります –

+0

SQLメソッドがありますが、覚えがたいです(nullで0を置き換えます) – alexay68

+0

:SELECT ISNULL(c.quantity、0)。構文は、使用しているデータベースのタイプに依存します – alexay68

0

この解決策を外部からお試しください。

drop table if exists dbo.tProduct; 
drop table if exists dbo.tPurchase; 
drop table if exists dbo.tSale; 

create table dbo.tProduct (
    id int 
    , product_name varchar(100) 
); 

create table dbo.tPurchase (
    id int 
    , quantity int 
); 

create table dbo.tSale (
    id int 
    , quantity int 
); 

insert into dbo.tProduct (id, product_name) 
values (1, 'apple'), (2, 'banana'), (3, 'mango'); 

insert into dbo.tPurchase (id, quantity) 
values (1, 15), (2, 10), (1, 5), (3, 25); 

insert into dbo.tSale (id, quantity) 
values (1, 5), (3, 10), (1, 5), (3, 5), (2, 5); 

select 
    p.id 
    , p.product_name 
    , pur.Quantity - sal.Quantity as Quantity 
from dbo.tProduct p 
    outer apply (
     select 
      sum(tp.quantity) as Quantity 
     from dbo.tPurchase tp 
     where p.id = tp.id 
    ) pur 
    outer apply (
     select 
      sum(tp.quantity) as Quantity 
     from dbo.tSale tp 
     where p.id = tp.id 
    ) sal 
+0

私はあなたのためにそれをチェックすることができます私の質問を変更しました –