跨三个表联接时值重复

时间:2019-11-08 12:10:27

标签: sql oracle join

我正在发布一些尝试将三个表连接在一起时输出中出现多个重复值的信息。我的数据结构如下:

T1(交易记录表)

Trans_ID    Acc_No    Trans_Code    Trans_Amt 
6243        11111111  0690          35.0  
4534        11111111  0876          10.0 
5987        22222222  0690          -10.0

T2(翻译表)

Acc_No    Prod_Code
11111111  45
22222222  65

T3(产品表)

Prod_Code    Prod_Desc
45           Current Account
65           Credit Card

翻译表(T2)允许通过交易(T1)进行组合,以查找该帐户是哪种产品(T3)。

  • 在T1中,Trans_ID始终是唯一的,但是Acc_No将出现 多次,Trans_Code也会
  • 在T2中,Acc_No是唯一的,但是Prod_Code将出现多次
  • 在T3中,Prod_Code是唯一的

我当前的尝试如下所示。该查询试图获取所有事务(T1),并计算按产品分组的不同类型(Trans_Type)中所有事务的总和和计数。 CASE WHEN将正值和负值分开。

SELECT T1.TRANS_CODE,
       T3.PROD_DESC,
       SUM  (CASE WHEN T1.TRANS_AMT < 0 THEN T1.TRANS_AMT ELSE 0 END) AS SUM_NEGATIVE,
       COUNT(CASE WHEN T1.TRANS_AMT < 0 THEN T1.TRANS_AMT END) AS COUNT_NEGATIVE,
       SUM  (CASE WHEN T1.TRANS_AMT > 0 THEN T1.TRANS_AMT ELSE 0 END) AS SUM_POSTIIVE,
       COUNT(CASE WHEN T1.TRANS_AMT > 0 THEN T1.TRANS_AMT END) AS COUNT_POSITIVE
FROM T1
LEFT JOIN T2
ON T1.ACC_NO = T2.ACC_NO
LEFT JOIN T3
ON T2.PROD_CODE = T3.PROD_CODE
GROUP BY T1.TRANS_CODE,
         T3.PROD_DESC

此处的预期输出为:

Trans_Type    Prod_Desc        Sum_Positive    Count_Positive    Sum_Negative    Count_Negative
0690          Current Account  35.0            1                 -               -     
0690          Credit Card      -               -                 -10.0           1 
0876          Current Account  10.0            1                 -               -

但是我的总和计数超出了我所知道的真实范围。

任何帮助都将不胜感激。

更新代码

SELECT T1.TRANS_CDE,
  T3.PROD_DESC,
SUM  (CASE WHEN T1.TRANS_AMT < 0 THEN T1.TRANS_AMT ELSE 0 END) AS SUM_NEGATIVE,
COUNT(CASE WHEN T1.TRANS_AMT < 0 THEN T1.TRANS_AMT END) AS COUNT_NEGATIVE,
SUM  (CASE WHEN T1.TRANS_AMT > 0 THEN T1.TRANS_AMT ELSE 0 END) AS SUM_POSTIIVE,
COUNT(CASE WHEN T1.TRANS_AMT > 0 THEN T1.TRANS_AMT END) AS COUNT_POSITIVE
FROM T1
LEFT JOIN (SELECT T2.ACC_NO, 
        MIN(PROD_CODE) AS PROD_CODE 
        FROM T2 
        GROUP BY ACC_NO) T2
ON T1.ACC_NO = T2.ACC_NO
LEFT JOIN T3
ON T2.PROD_CODE = T3.PROD_CODE
GROUP BY T1.TRAN_CDE,
  T3.PROD_DESC

1 个答案:

答案 0 :(得分:1)

这个评论太长了。

根据表的描述,您的查询看起来不错。如果您的人数过多,我想您的其中一张表有意外的重复。

这两个都返回任何行吗?

select ac_no
from t2
group by ac_no
having count(*) >= 2;

select prod_code
from t3
group by prod_code
having count(*) >= 2;

如果这些查询不返回任何行,则该查询似乎在返回正确的值。

编辑:

有两种方法从T2中仅选择一行。仅在FROM子句中需要更改:

FROM T1 LEFT JOIN
     (SELECT T2.ACC_NO, MIN(t2.PROD_CODE) as PROD_CODE
      FROM T2
      GROUP BY T2.ACC_NO
     ) T2
     ON T1.ACC_NO = T2.ACC_NO LEFT JOIN
     T3
     ON T2.PROD_CODE = T3.PROD_CODE

或者:

FROM T1 LEFT JOIN
     (SELECT T2.*,
             ROW_NUMBER() OVER (PARTITION BY T2.ACC_NO ORDER BY T2.ACC_NO) as seqnum
      FROM T2
      GROUP BY T2.ACC_NO
     ) T2
     ON T1.ACC_NO = T2.ACC_NO AND
        T2.seqnum = 1 LEFT JOIN
     T3
     ON T2.PROD_CODE = T3.PROD_CODE