dev #337

Merged
ysCha merged 3 commits from dev into dev-deploy 2026-01-22 13:42:59 +09:00
Showing only changes of commit 65a0fd430e - Show all commits

View File

@ -367,37 +367,54 @@
<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[
SELECT SELECT SUM (
CAST(SUM(F.VOL_KW) AS NUMERIC(18, 3)) AS CERT_VOL_KW CAST (ISNULL(
FROM ( CASE WHEN ISNULL(B.PQ_VOL, 0) = 0
SELECT THEN (CASE WHEN B.P_VOL < B.M_VOL THEN B.P_VOL ELSE B.M_VOL END)
T.*, ELSE (CASE WHEN B.PQ_VOL < B.M_VOL THEN B.PQ_VOL ELSE B.M_VOL END)
ROUND((T.AMOUNT * CAST(ISNULL(T.M_SPEC, 0) AS FLOAT) / 1000), 4) AS MODULE_VOL_KW, END, 0) AS NUMERIC(18, 3))) AS CERT_VOL_KW
ROUND((T.AMOUNT * CAST(ISNULL(T.P_SPEC, 0) AS FLOAT) / 1000), 4) AS PC_VOL_KW,
CASE
WHEN ROUND((T.AMOUNT * CAST(ISNULL(T.M_SPEC, 0) AS FLOAT) / 1000), 4)
< ROUND((T.AMOUNT * CAST(ISNULL(T.P_SPEC, 0) AS FLOAT) / 1000), 4)
THEN ROUND((T.AMOUNT * CAST(ISNULL(T.M_SPEC, 0) AS FLOAT) / 1000), 4)
ELSE ROUND((T.AMOUNT * CAST(ISNULL(T.P_SPEC, 0) AS FLOAT) / 1000), 4)
END AS VOL_KW
FROM ( FROM (
SELECT DISTINCT SELECT DISTINCT
TPR.ITEM_ID, A.P_ITEM_ID
TPR.ITEM_NO, , (SELECT ROUND((TE.AMOUNT * CAST(ISNULL(TE.SPECIFICATION,0) AS FLOAT) / 1000), 4)
TPR.ITEM_NAME, FROM T_PART_ESTIMATE TE (NOLOCK)
TPR.SPECIFICATION AS M_SPEC, WHERE TE.OBJECT_NO = A.OBJECT_NO AND TE.PLAN_NO = A.PLAN_NO AND TE.ITEM_ID = A.P_ITEM_ID) AS P_VOL
TPR.AMOUNT, , TRI.QCAST_CUST_PRD_ID
TPC.ITEM_ID AS PC_ITEM_ID, , (SELECT ROUND((TE.AMOUNT * CAST(ISNULL(TE.SPECIFICATION,0) AS FLOAT) / 1000), 4)
(SELECT PNOW_W FROM M_ITEM WHERE ITEM_ID = TPC.ITEM_ID) AS P_SPEC, FROM T_PART_ESTIMATE TE (NOLOCK)
TPC.CIRCUIT_CFG WHERE TE.OBJECT_NO = A.OBJECT_NO AND TE.PLAN_NO = A.PLAN_NO AND TE.ITEM_ID = TRI.QCAST_CUST_PRD_ID) AS PQ_VOL
FROM T_PART_CIRCUIT_ITEM_ESTIMATE TPC , TRI.ITEM_ID AS M_ITEM_ID
INNER JOIN T_PART_ROOF_ITEM_ESTIMATE TPR , (SELECT ROUND((A.M_AMT * CAST(ISNULL(TE.SPECIFICATION,0) AS FLOAT) / 1000), 4)
ON TPC.OBJECT_NO = TPR.OBJECT_NO FROM T_PART_ESTIMATE TE (NOLOCK)
AND TPC.PLAN_NO = TPR.PLAN_NO WHERE TE.OBJECT_NO = A.OBJECT_NO AND TE.PLAN_NO = A.PLAN_NO AND TE.ITEM_ID = TRI.ITEM_ID) AS M_VOL
WHERE TPC.OBJECT_NO = #{objectNo} , A.M_AMT
AND TPC.PLAN_NO = #{planNo} FROM (
) T SELECT
) F TPC.OBJECT_NO
, TPC.PLAN_NO
, TPC.ITEM_ID AS P_ITEM_ID
, TPC.CIRCUIT_CFG
,(
SELECT SUM(CAST(T.Item AS INT))
FROM (
SELECT CAST('<X>' + REPLACE(TPC.CIRCUIT_CFG, ',', '</X><X>') + '</X>' AS XML) AS XMLDATA
) AS Sub
CROSS APPLY (
SELECT f.x.value('.', 'VARCHAR(MAX)') AS Item
FROM Sub.XMLDATA.nodes('/X') AS f(x)
) AS T
WHERE T.Item <> ''
) AS M_AMT
FROM T_PART_CIRCUIT_ITEM_ESTIMATE TPC (NOLOCK)
WHERE
TPC.OBJECT_NO = #{objectNo}
AND
TPC.PLAN_NO = #{planNo}
)A
LEFT OUTER JOIN T_PART_ROOF_ITEM_ESTIMATE TRI (NOLOCK)
ON A.OBJECT_NO = TRI.OBJECT_NO
AND A.PLAN_NO = TRI.PLAN_NO
)B
]]> ]]>
</select> </select>