[sql]在case語句中不同情況下then的數據的數據類型不一致ORA-00932: inconsistent datatypes: expected NUMBER got CHAR


ORA-00932: inconsistent datatypes: expected NUMBER got CHAR

00932. 00000 -  "inconsistent datatypes: expected %s got %s"

 

1 CASE XXXXX.FILE_TYPE 
2         WHEN '0' THEN  NVL(TX_CNT,0)
3         ELSE XXXXX.TOT_TX_CNT 
4 END  ACT_TX_CNT,
TX_CNT為NUMBER型,是GROUP BY 后的計數量
TOT_TX_CNT是VARCHAR2(XX)類型

故出現上述錯誤提示。

解決方案:進行數據轉換,將NUMBER型數據轉換成VACHAR2(XX)類型
1 CASE XXXXX.FILE_TYPE 
2     WHEN '0' THEN CAST( NVL(ACT_TX_CNT,0) AS VARCHAR2(8)) 
3     ELSE EPSTFBOK.TOT_TX_CNT 
4 END ACT_TX_CNT,

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

完整代碼小記:

統計文件對應的交易筆數,交易金額,有效的交易筆數,有效的交易金額
1
SELECT EPSTFBOK.FILE_DT, 2 EPSTFBOK.FILE_TYPE, 3 EPSTFBOK.FILE_SRC, 4 EPSTFBOK.FIL_STS, 5 EPSTFBOK.RCV_FIL, 6 EPSTFBOK.TOT_TX_CNT, 7 EPSTFBOK.TOT_TX_AMT, 8 EPSTFBOK.RMK, 9 EPSTFBOK.BAT_NO, 10 nvl( CHUI_CNT,0) CHUI_CNT, 11 CASE EPSTFBOK.FILE_TYPE WHEN '0' THEN CAST( NVL(ACT_TX_CNT,0) AS VARCHAR2(8)) ELSE EPSTFBOK.TOT_TX_CNT END ACT_TX_CNT, 12 CASE EPSTFBOK.FILE_TYPE WHEN '0' THEN CAST(NVL(ACT_TX_AMT,0) AS VARCHAR(15)) ELSE EPSTFBOK.TOT_TX_AMT END ACT_TX_AMT 13 FROM EPSTFBOK 14 LEFT JOIN 15 (SELECT BAT_NO,COUNT(*) CHUI_CNT FROM EPSTORDR WHERE ALT_FLG='1' GROUP BY BAT_NO) 16 M ON epstfbok.bat_no = m.bat_no 17 LEFT JOIN 18 (SELECT BAT_NO,COUNT(*) ACT_TX_CNT, SUM(TX_AMT) ACT_TX_AMT FROM EPSTORDR GROUP BY BAT_NO ) 19 N ON epstfbok.bat_no = N.bat_no 20 ORDER BY EPSTFBOK.BAT_NO desc;

 

 

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM