[1375]인증용량 계산수정6

This commit is contained in:
ysCha 2026-02-04 11:18:56 +09:00
parent 9d620e85a9
commit 96e101025c

View File

@ -367,55 +367,68 @@
<select id="selectEstimateRoofCertVolKw" parameterType="com.interplug.qcast.biz.estimate.dto.EstimateRequest" resultType="String"> <select id="selectEstimateRoofCertVolKw" parameterType="com.interplug.qcast.biz.estimate.dto.EstimateRequest" resultType="String">
/* sqlid : com.interplug.qcast.biz.estimate.selectEstimateRoofCertVolKw */ /* sqlid : com.interplug.qcast.biz.estimate.selectEstimateRoofCertVolKw */
<![CDATA[ <![CDATA[
;WITH TCI AS ( ;WITH
SELECT TCI AS (
TI.CIRCUIT_NO, SELECT
TI.OBJECT_NO, TI.CIRCUIT_NO,
TI.PLAN_NO, TI.OBJECT_NO,
TI.ITEM_ID, TI.PLAN_NO,
TI.CIRCUIT_CFG, TI.ITEM_ID,
COUNT(*) AS P_AMT TI.CIRCUIT_CFG,
FROM T_PART_CIRCUIT_ITEM_ESTIMATE TI COUNT(*) AS P_AMT
GROUP BY TI.CIRCUIT_NO, TI.OBJECT_NO, TI.PLAN_NO, TI.ITEM_ID, TI.CIRCUIT_CFG FROM
), T_PART_CIRCUIT_ITEM_ESTIMATE TI
Z AS ( GROUP BY
SELECT TI.CIRCUIT_NO,
TRI.ROOF_ITEM_NO, TI.OBJECT_NO,
TRI.OBJECT_NO, TI.PLAN_NO,
TRI.PLAN_NO, TI.ITEM_ID,
TRI.ITEM_ID AS M_ITEM_ID, TI.CIRCUIT_CFG
TRI.ITEM_NO, ),
TRI.SPECIFICATION AS M_SPEC, Z AS (
TRI.AMOUNT AS M_AMT, SELECT
TCI.ITEM_ID AS P_ITEM_ID, TRI.ROOF_ITEM_NO,
TCI.P_AMT, TRI.OBJECT_NO,
TCI.CIRCUIT_CFG TRI.PLAN_NO,
FROM T_PART_ROOF_ITEM_ESTIMATE TRI TRI.ITEM_ID AS M_ITEM_ID,
INNER JOIN T_PART_ROOF_ESTIMATE TR TRI.ITEM_NO,
ON TRI.ROOF_SURFACE_ID = TR.ROOF_SURFACE_ID TRI.SPECIFICATION AS M_SPEC,
AND TRI.OBJECT_NO = TR.OBJECT_NO TRI.AMOUNT AS M_AMT,
AND TRI.PLAN_NO = TR.PLAN_NO TCI.ITEM_ID AS P_ITEM_ID,
INNER JOIN TCI TRI.PC_ITEM_ID,
ON TRI.ROOF_ITEM_NO = TCI.CIRCUIT_NO TRI.QCAST_CUST_PRD_ID,
AND TRI.OBJECT_NO = TCI.OBJECT_NO TCI.P_AMT,
AND TRI.PLAN_NO = TCI.PLAN_NO TCI.CIRCUIT_CFG
WHERE TRI.OBJECT_NO = #{objectNo} FROM
AND TRI.PLAN_NO = #{planNo} T_PART_ROOF_ITEM_ESTIMATE TRI
), INNER JOIN T_PART_ROOF_ESTIMATE TR ON TRI.ROOF_SURFACE_ID = TR.ROOF_SURFACE_ID
Z_CFG AS ( AND TRI.OBJECT_NO = TR.OBJECT_NO
SELECT AND TRI.PLAN_NO = TR.PLAN_NO
Z.*, INNER JOIN TCI ON TRI.ROOF_ITEM_NO = TCI.CIRCUIT_NO
CAST(ISNULL(SPLIT.M_1, 0) AS INT) AS M_1, AND TRI.OBJECT_NO = TCI.OBJECT_NO
CAST(ISNULL(SPLIT.M_2, 0) AS INT) AS M_2, AND TRI.PLAN_NO = TCI.PLAN_NO
CAST(ISNULL(SPLIT.M_3, 0) AS INT) AS M_3 WHERE
FROM Z TRI.OBJECT_NO = #{objectNo}
CROSS APPLY ( AND TRI.PLAN_NO = #{planNo}
),
Z_CFG AS (
SELECT
Z.*,
CAST(ISNULL(SPLIT.M_1, 0) AS INT) AS M_1,
CAST(ISNULL(SPLIT.M_2, 0) AS INT) AS M_2,
CAST(ISNULL(SPLIT.M_3, 0) AS INT) AS M_3
FROM
Z CROSS APPLY (
SELECT SELECT
X.value('(/x[1]/v[1])[1]', 'VARCHAR(50)') AS M_1, X.value('(/x[1]/v[1])[1]', 'VARCHAR(50)') AS M_1,
X.value('(/x[1]/v[2])[1]', 'VARCHAR(50)') AS M_2, X.value('(/x[1]/v[2])[1]', 'VARCHAR(50)') AS M_2,
X.value('(/x[1]/v[3])[1]', 'VARCHAR(50)') AS M_3 X.value('(/x[1]/v[3])[1]', 'VARCHAR(50)') AS M_3
FROM ( FROM
SELECT CAST('<x><v>' + REPLACE(ISNULL(Z.CIRCUIT_CFG, ''), ',', '</v><v>') + '</v></x>' AS XML) (
SELECT
CAST(
'<x><v>' + REPLACE(ISNULL(Z.CIRCUIT_CFG, ''), ',', '</v><v>') + '</v></x>' AS XML
)
) A(X) ) A(X)
) SPLIT ) SPLIT
), ),
@ -429,42 +442,61 @@
ZC.P_ITEM_ID, ZC.P_ITEM_ID,
TE.SPECIFICATION AS P_SPEC, TE.SPECIFICATION AS P_SPEC,
ZC.P_AMT, ZC.P_AMT,
(SELECT SPECIFICATION (
FROM T_PART_ROOF_ITEM_ESTIMATE TRI SELECT
INNER JOIN T_PART_ROOF_ESTIMATE TR SPECIFICATION
ON TRI.ROOF_SURFACE_ID = TR.ROOF_SURFACE_ID FROM
AND TRI.OBJECT_NO = TR.OBJECT_NO T_PART_ROOF_ITEM_ESTIMATE TRI
AND TRI.PLAN_NO = TR.PLAN_NO INNER JOIN T_PART_ROOF_ESTIMATE TR ON TRI.ROOF_SURFACE_ID = TR.ROOF_SURFACE_ID
WHERE TRI.OBJECT_NO = ZC.OBJECT_NO AND TRI.OBJECT_NO = TR.OBJECT_NO
AND TRI.PLAN_NO = TR.PLAN_NO
WHERE
TRI.OBJECT_NO = ZC.OBJECT_NO
AND TRI.PLAN_NO = ZC.PLAN_NO AND TRI.PLAN_NO = ZC.PLAN_NO
AND TRI.ROOF_ITEM_NO = (ZC.ROOF_ITEM_NO + 1)) AS M_SPEC2 AND TRI.ROOF_ITEM_NO = (ZC.ROOF_ITEM_NO + 1)
FROM Z_CFG ZC ) AS M_SPEC2
INNER JOIN T_PART_ESTIMATE TE FROM
ON ZC.OBJECT_NO = TE.OBJECT_NO Z_CFG ZC
AND ZC.PLAN_NO = TE.PLAN_NO INNER JOIN T_PART_ESTIMATE TE ON ZC.OBJECT_NO = TE.OBJECT_NO
AND ZC.P_ITEM_ID = TE.ITEM_ID AND ZC.PLAN_NO = TE.PLAN_NO
AND 0 < CAST(TE.SPECIFICATION AS FLOAT)
AND TE.ITEM_ID IN (ZC.P_ITEM_ID, ZC.PC_ITEM_ID, ZC.QCAST_CUST_PRD_ID)
), ),
X AS ( X AS (
SELECT SELECT
Y.M_ITEM_ID, Y.M_ITEM_ID,
Y.M_SPEC, Y.M_SPEC,
(Y.M_AMT2 - Y.M_AMT) AS M_CNT, (Y.M_AMT2 - Y.M_AMT) AS M_CNT,
ROUND((Y.M_AMT * CAST(ISNULL(Y.M_SPEC, 0) AS FLOAT) / 1000), 4) AS M_VOL, ROUND((Y.M_AMT * CAST(ISNULL(Y.M_SPEC, 0) AS FLOAT) / 1000), 4) AS M_VOL,
ROUND((Y.M_AMT2 * CAST(ISNULL(Y.M_SPEC, 0) AS FLOAT) / 1000), 4) AS M_VOL2, ROUND(
ROUND(((Y.M_AMT2 - Y.M_AMT) * CAST(ISNULL(Y.M_SPEC, 0) AS FLOAT) / 1000), 4) AS R_VOL, (Y.M_AMT2 * CAST(ISNULL(Y.M_SPEC, 0) AS FLOAT) / 1000),
4
) AS M_VOL2,
ROUND(
(
(Y.M_AMT2 - Y.M_AMT) * CAST(ISNULL(Y.M_SPEC, 0) AS FLOAT) / 1000
),
4
) AS R_VOL,
CASE CASE
WHEN Y.M_AMT < Y.M_AMT2 WHEN Y.M_AMT < Y.M_AMT2 THEN ROUND((Y.M_AMT * CAST(ISNULL(Y.M_SPEC, 0) AS FLOAT) / 1000), 4)
THEN ROUND((Y.M_AMT * CAST(ISNULL(Y.M_SPEC, 0) AS FLOAT) / 1000), 4) ELSE ROUND(
ELSE (Y.M_AMT2 * CAST(ISNULL(Y.M_SPEC, 0) AS FLOAT) / 1000),
ROUND((Y.M_AMT2 * CAST(ISNULL(Y.M_SPEC, 0) AS FLOAT) / 1000), 4) 4
)
END AS M_VOL_KW, END AS M_VOL_KW,
ROUND((Y.P_AMT * CAST(ISNULL(Y.P_SPEC, 0) AS FLOAT) / 1000), 4) AS PC_VOL_KW, ROUND((Y.P_AMT * CAST(ISNULL(Y.P_SPEC, 0) AS FLOAT) / 1000), 4) AS PC_VOL_KW,
CASE CASE
WHEN 0 < (Y.M_AMT2 - Y.M_AMT) WHEN 0 < (Y.M_AMT2 - Y.M_AMT) THEN ROUND(
THEN ROUND(((Y.M_AMT2 - Y.M_AMT) * CAST(ISNULL(Y.M_SPEC2, 0) AS FLOAT) / 1000), 4) (
(Y.M_AMT2 - Y.M_AMT) * CAST(ISNULL(Y.M_SPEC2, 0) AS FLOAT) / 1000
),
4
)
ELSE 0 ELSE 0
END AS M_VOL_KW2 END AS M_VOL_KW2
FROM Y FROM
Y
) )
SELECT SELECT
SUM( SUM(
@ -474,7 +506,8 @@
ELSE 0 ELSE 0
END END
) AS CERT_VOL_KW ) AS CERT_VOL_KW
FROM X; FROM
X;
]]> ]]>
</select> </select>