私はdb2を使用していますが、どのバージョンかわかりません。テーブルを合計しようとすると、オーバーフロー エラーが発生します。合計をBIGINTにキャストできると思っていましたが、これは合計で機能しているように見えますが、パーセンテージを求めていて、BIGINTにキャストするとデータが不正確になります。Percent_DeliveredB/A の正確なパーセンテージを取得するにはどうすればよいですか? 分子と分母を BIGINT に変換し、パーセンテージで割っても正しい結果が得られません。
これが私のスクリプトです:
SELECT
FAT.DIM_BUILDING_ID,
FAT.BUILDING_NAME,
SUM(CAST(FAT.AMOUNT AS BIGINT)) AS SALES_SUM,
SUM(CAST(FAT.ORDERS AS BIGINT)) AS ORDERS_SUM,
SUM(CAST(FAT.CAPABILITY AS BIGINT)) AS CAPABILITY_SUM,
SUM(FAT.ORDERS_B)/sum(FAT.Amount) AS Percent_DeliveredB,
SUM(FAT.ORDERS_A)/sum(FAT.Amount) AS Percent_DeliveredA,
SUM(CAST(FTS.GROUP_A AS BIGINT)) AS GROUP_A,
SUM(CAST(FTS.GROUP_B AS BIGINT)) AS GROUP_B,
SUM(CAST(FTS.GROUP_C AS BIGINT)) AS GROUP_C
FROM ORDERS AS FAT
INNER JOIN GROUPS AS FTS ON FAT.DIM_PROJECT_ID = FTS.DIM_PROJECT_ID
GROUP BY FAT.DIM_BUILDING_ID, FAT.BUILDING_NAME;
次のことを試しましたが、パーセンテージが0で返されます。
SUM(CAST(FAT.ORDERS_B AS BIGINT))/sum(CAST(FAT.Amount AS BIGINT)) AS Percent_DeliveredB