Merge pull request '[1375]인증용량 pcs 관련 스펙 추가' (#380) from dev into prd-deploy

Reviewed-on: #380
This commit is contained in:
ysCha 2026-02-09 11:20:32 +09:00
commit 8325f05983

View File

@ -368,119 +368,111 @@
/* sqlid : com.interplug.qcast.biz.estimate.selectEstimateRoofCertVolKw */ /* sqlid : com.interplug.qcast.biz.estimate.selectEstimateRoofCertVolKw */
<![CDATA[ <![CDATA[
;WITH TCI AS ( ;WITH TCI AS (
SELECT SELECT
TI.CIRCUIT_NO, TI.CIRCUIT_NO,
TI.OBJECT_NO, TI.OBJECT_NO,
TI.PLAN_NO, TI.PLAN_NO,
TI.ITEM_ID, TI.ITEM_ID,
TI.CIRCUIT_CFG, TI.CIRCUIT_CFG,
COUNT(*) AS P_AMT COUNT(*) AS P_AMT
FROM FROM T_PART_CIRCUIT_ITEM_ESTIMATE TI
T_PART_CIRCUIT_ITEM_ESTIMATE TI GROUP BY TI.CIRCUIT_NO, TI.OBJECT_NO, TI.PLAN_NO, TI.ITEM_ID, TI.CIRCUIT_CFG
GROUP BY ),
TI.CIRCUIT_NO, Z AS (
TI.OBJECT_NO, SELECT
TI.PLAN_NO, TRI.ROOF_ITEM_NO,
TI.ITEM_ID, TRI.OBJECT_NO,
TI.CIRCUIT_CFG TRI.PLAN_NO,
), TRI.ITEM_ID AS M_ITEM_ID,
Z AS ( TRI.ITEM_NO,
SELECT TRI.SPECIFICATION AS M_SPEC,
TRI.ROOF_ITEM_NO, TRI.AMOUNT AS M_AMT,
TRI.OBJECT_NO, TCI.ITEM_ID AS P_ITEM_ID,
TRI.PLAN_NO, TRI.PC_ITEM_ID,
TRI.ITEM_ID AS M_ITEM_ID, TRI.QCAST_CUST_PRD_ID,
TRI.ITEM_NO, TCI.P_AMT
TRI.SPECIFICATION AS M_SPEC, , (SELECT ISNULL(M.PNOW_W,0) FROM M_ITEM M WHERE M.ITEM_ID = TCI.ITEM_ID) AS P_SPEC
TRI.AMOUNT AS M_AMT, , (SELECT ISNULL(M.PNOW_W,0) FROM M_ITEM M WHERE M.ITEM_ID = TRI.PC_ITEM_ID) AS PC_SPEC
TCI.ITEM_ID AS P_ITEM_ID, , (SELECT ISNULL(M.PNOW_W,0) FROM M_ITEM M WHERE M.ITEM_ID = TRI.QCAST_CUST_PRD_ID) AS CUST_SPEC
TRI.PC_ITEM_ID, ,TCI.CIRCUIT_CFG
TRI.QCAST_CUST_PRD_ID, FROM T_PART_ROOF_ITEM_ESTIMATE TRI
TCI.P_AMT, INNER JOIN TCI
TCI.CIRCUIT_CFG ON TRI.ROOF_ITEM_NO = TCI.CIRCUIT_NO
FROM AND TRI.OBJECT_NO = TCI.OBJECT_NO
T_PART_ROOF_ITEM_ESTIMATE TRI AND TRI.PLAN_NO = TCI.PLAN_NO
INNER JOIN T_PART_ROOF_ESTIMATE TR ON TRI.ROOF_SURFACE_ID = TR.ROOF_SURFACE_ID WHERE
AND TRI.OBJECT_NO = TR.OBJECT_NO TRI.OBJECT_NO = #{objectNo}
AND TRI.PLAN_NO = TR.PLAN_NO AND
INNER JOIN TCI ON TRI.ROOF_ITEM_NO = TCI.CIRCUIT_NO TRI.PLAN_NO = #{planNo}
AND TRI.OBJECT_NO = TCI.OBJECT_NO ),
AND TRI.PLAN_NO = TCI.PLAN_NO Z_CFG AS (
WHERE SELECT
TRI.OBJECT_NO = #{objectNo} Z.*,
AND TRI.PLAN_NO = #{planNo} CAST(ISNULL(SPLIT.M_1, 0) AS INT) AS M_1,
), CAST(ISNULL(SPLIT.M_2, 0) AS INT) AS M_2,
Z_CFG AS ( CAST(ISNULL(SPLIT.M_3, 0) AS INT) AS M_3
SELECT FROM Z
Z.*, CROSS APPLY (
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 ) A(X)
CAST( ) SPLIT
'<x><v>' + REPLACE(ISNULL(Z.CIRCUIT_CFG, ''), ',', '</v><v>') + '</v></x>' AS XML ),
)
) A(X)
) SPLIT
),
Y AS ( Y AS (
SELECT SELECT
ZC.ROOF_ITEM_NO, ZC.ROOF_ITEM_NO,
ZC.M_ITEM_ID, ZC.M_ITEM_ID,
ZC.M_SPEC, ZC.M_SPEC,
ZC.M_AMT, ZC.M_AMT,
(ZC.M_1 + ZC.M_2 + ZC.M_3) AS M_AMT2, (ZC.M_1 + ZC.M_2 + ZC.M_3) AS M_AMT2,
ZC.P_ITEM_ID, ZC.P_ITEM_ID,
TE.SPECIFICATION AS P_SPEC, ZC.P_AMT,
ZC.P_AMT, ZC.PC_ITEM_ID,
( ZC.QCAST_CUST_PRD_ID,
SELECT CASE
SPECIFICATION WHEN ZC.P_SPEC != '0' THEN P_SPEC
FROM WHEN ZC.CUST_SPEC != '0' THEN CUST_SPEC
T_PART_ROOF_ITEM_ESTIMATE TRI WHEN ZC.PC_SPEC != '0' THEN PC_SPEC
INNER JOIN T_PART_ROOF_ESTIMATE TR ON TRI.ROOF_SURFACE_ID = TR.ROOF_SURFACE_ID ELSE '0'
AND TRI.OBJECT_NO = TR.OBJECT_NO END
AND TRI.PLAN_NO = TR.PLAN_NO AS P_SPEC,
WHERE (SELECT SPECIFICATION
TRI.OBJECT_NO = ZC.OBJECT_NO FROM T_PART_ROOF_ITEM_ESTIMATE
AND TRI.PLAN_NO = ZC.PLAN_NO WHERE OBJECT_NO = ZC.OBJECT_NO
AND TRI.ROOF_ITEM_NO = (ZC.ROOF_ITEM_NO + 1) AND PLAN_NO = ZC.PLAN_NO
) AS M_SPEC2 AND ROOF_ITEM_NO = (ZC.ROOF_ITEM_NO + 1)) AS M_SPEC2
FROM FROM Z_CFG ZC
Z_CFG ZC INNER JOIN T_PART_ESTIMATE TE
INNER JOIN T_PART_ESTIMATE TE ON ZC.OBJECT_NO = TE.OBJECT_NO ON ZC.OBJECT_NO = TE.OBJECT_NO
AND ZC.PLAN_NO = TE.PLAN_NO 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) 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( ROUND((Y.M_AMT2 * CAST(ISNULL(Y.M_SPEC, 0) AS FLOAT) / 1000), 4) AS M_VOL2,
(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,
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 THEN ROUND((Y.M_AMT * CAST(ISNULL(Y.M_SPEC, 0) AS FLOAT) / 1000), 4) WHEN Y.M_AMT < Y.M_AMT2
ELSE ROUND((Y.M_AMT2 * 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((Y.M_AMT2 * CAST(ISNULL(Y.M_SPEC, 0) AS FLOAT) / 1000), 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) THEN ROUND(((Y.M_AMT2 - Y.M_AMT) * CAST(ISNULL(Y.M_SPEC2, 0) AS FLOAT) / 1000),4) WHEN 0 < (Y.M_AMT2 - Y.M_AMT)
THEN ROUND(((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 FROM Y
Y ) )
SELECT SELECT
CAST( CAST(
SUM( SUM(