dev #338

Merged
ysCha merged 3 commits from dev into prd-deploy 2026-01-22 13:43:14 +09:00
3 changed files with 78 additions and 51 deletions

View File

@ -2288,34 +2288,42 @@ public class PwrGnrSimService {
// 상단 요약정보 // 상단 요약정보
elm = doc.getElementById("objectNo"); elm = doc.getElementById("objectNo");
elm.text( if (elm != null) {
StringUtils.defaultString(data.getObjectNo() + " (Plan No : " + data.getPlanNo() + ")")); elm.text(
StringUtils.defaultString(data.getObjectNo() + " (Plan No : " + data.getPlanNo() + ")"));
}
elm = doc.getElementById("drawingEstimateCreateDate"); elm = doc.getElementById("drawingEstimateCreateDate");
elm.text(StringUtils.defaultString(data.getDrawingEstimateCreateDate())); if (elm != null) {
elm.text(StringUtils.defaultString(data.getDrawingEstimateCreateDate()));
}
elm = doc.getElementById("prefName"); elm = doc.getElementById("prefName");
if (elm != null) {
elm.text(StringUtils.defaultString(data.getPrefName())); elm.text(StringUtils.defaultString(data.getPrefName()));
}
elm = doc.getElementById("areaName"); elm = doc.getElementById("areaName");
elm.text(StringUtils.defaultString(data.getAreaName())); if (elm != null) {
elm.text(StringUtils.defaultString(data.getAreaName()));
}
elm = doc.getElementById("capacity"); elm = doc.getElementById("capacity");
elm.text(StringUtils.defaultString(data.getCapacity()) + " kW"); if (elm != null) {
elm.text(StringUtils.defaultString(data.getCapacity()) + " kW");
}
elm = doc.getElementById("anlFrcsGnrt"); elm = doc.getElementById("anlFrcsGnrt");
elm.text(StringUtils.defaultString(String.valueOf(pwrGnrSimList[12]))); if (elm != null) {
elm.text(StringUtils.defaultString(String.valueOf(pwrGnrSimList[12])));
}
elm = doc.getElementById("snowfall"); elm = doc.getElementById("snowfall");
elm.text(StringUtils.defaultString(data.getSnowfall()) + " cm"); if (elm != null) {
elm.text(StringUtils.defaultString(data.getSnowfall()) + " cm");
}
elm = doc.getElementById("standardWindSpeedId"); elm = doc.getElementById("standardWindSpeedId");
elm.text(StringUtils.defaultString(data.getStandardWindSpeedId())); if (elm != null) {
elm.text(StringUtils.defaultString(data.getStandardWindSpeedId()));
}
elm = doc.getElementById("pwrGnrSimTypeName"); elm = doc.getElementById("pwrGnrSimTypeName");
elm.text(StringUtils.defaultString(data.getPwrGnrSimTypeName())); if (elm != null) {
elm.text(StringUtils.defaultString(data.getPwrGnrSimTypeName()));
}
boolean isUnchanged = Arrays.stream(pwrGnrSimList).allMatch(value -> value == "00"); boolean isUnchanged = Arrays.stream(pwrGnrSimList).allMatch(value -> value == "00");
if (!isUnchanged) { // 변경된값 확인 if (!isUnchanged) { // 변경된값 확인

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

View File

@ -104,8 +104,10 @@
WHEN A.CLASS_TYPE = 0 THEN A.SLOPE WHEN A.CLASS_TYPE = 0 THEN A.SLOPE
ELSE A.ANGLE END) AS SLOPE_ANGLE ELSE A.ANGLE END) AS SLOPE_ANGLE
, (CASE , (CASE
WHEN A.CLASS_TYPE = 0 THEN CAST(CAST(A.SLOPE AS INT)AS VARCHAR) + '寸' WHEN A.CLASS_TYPE = 0
ELSE CAST(CAST(A.ANGLE AS INT)AS VARCHAR) + N'º' END) AS SLOPE_ANGLE_TXT THEN CAST(CAST(A.SLOPE AS FLOAT) AS VARCHAR) + '寸'
ELSE CAST(CAST(A.ANGLE AS FLOAT) AS VARCHAR) + N'º'
END) AS SLOPE_ANGLE_TXT
FROM T_PART_ROOF_ESTIMATE A WITH (NOLOCK) FROM T_PART_ROOF_ESTIMATE A WITH (NOLOCK)
INNER JOIN T_PART_ROOF_ITEM_ESTIMATE B WITH (NOLOCK) INNER JOIN T_PART_ROOF_ITEM_ESTIMATE B WITH (NOLOCK)
ON A.OBJECT_NO = B.OBJECT_NO ON A.OBJECT_NO = B.OBJECT_NO