From a7cc9c3be58bccd868bc8c12ed57c2b90fedc6b8 Mon Sep 17 00:00:00 2001
From: chenlu <1320612696@qq.com>
Date: 星期四, 05 十二月 2024 17:02:59 +0800
Subject: [PATCH] Merge branch 'master' of http://10.153.19.25:10105/r/ERP_override

---
 north-glass-erp/src/main/resources/mapper/pp/GlassOptimize.xml |   93 ++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 93 insertions(+), 0 deletions(-)

diff --git a/north-glass-erp/src/main/resources/mapper/pp/GlassOptimize.xml b/north-glass-erp/src/main/resources/mapper/pp/GlassOptimize.xml
index ffa719f..9c02619 100644
--- a/north-glass-erp/src/main/resources/mapper/pp/GlassOptimize.xml
+++ b/north-glass-erp/src/main/resources/mapper/pp/GlassOptimize.xml
@@ -58,6 +58,37 @@
         <result property="modifyTime" column="modify time"/>
     </resultMap>
 
+    <!--宸ョ▼淇℃伅-->
+    <select id="projectInfoMp">
+        SELECT
+            f.order_number,
+            g.child_width ,
+            g.child_height ,
+            f.quantity ,
+            d.shape ,
+            op.process_cards ,
+            d.product_name ,
+            op.remark ,
+            d.building_number ,
+            round(((`g`.`child_width` + g.child_height) * 2 * `f`.`quantity`),2) as perimeter ,
+            round((`g`.`area` * `f`.`quantity`),4) AS area,
+            f.technology_number ,
+            g.glass_child ,
+            g.icon,
+            op.project_name
+        FROM
+            ((pp.flow_card AS f
+                LEFT JOIN sd.order_detail AS d ON (((f.order_id = d.order_id) AND (f.order_number = d.order_number))))
+                LEFT JOIN sd.order_glass_detail AS g ON (((f.order_id = g.order_id) AND (f.order_number = g.order_number) AND (f.technology_number = g.technology_number))))
+                INNER JOIN pp.optimize_project AS op ON op.project_no = f.project_no
+        WHERE
+            f.project_no = #{projectNo}
+        GROUP BY
+            f.order_id,
+            f.technology_number,
+            f.order_number;
+    </select>
+
     <select id="selectWordOrder" resultMap="wordOrderMap">
         select
         o.order_id,
@@ -133,6 +164,7 @@
         ORDER BY fc.process_id, fc.technology_number
     </select>
 
+        <!--宸ョ▼绠$悊-->
     <select id="optimizeProjectMangeMp"  resultMap="optimizeProjectMangeMap">
         select p.`id`                                AS `id`,
                p.`project_no`                        AS `Project Number`,
@@ -212,4 +244,65 @@
             p.project_no
     </select>
 
+    <!--妯℃嫙璁$畻鏌ヨ娴佺▼鍗�-->
+    <select id="selectProjectComputeMp">
+        SELECT
+            fc.process_id,
+            fc.technology_number,
+            fc.project_no,
+            fcss.TotalFloors,
+            COUNT(fc.order_number)                                      AS TotalNumber,
+            SUM(fc.quantity)                                            AS quantity,
+            ROUND(SUM(od.width * od.height * fc.quantity / 1000000), 2) AS area,
+            o.project,
+            ogd.glass_child,
+            od.shape
+        FROM
+            pp.flow_card AS fc
+                LEFT JOIN sd.`order` AS o ON fc.order_id = o.order_id
+                LEFT JOIN sd.order_detail AS od ON od.order_id = fc.order_id AND od.order_number = fc.order_number
+                LEFT JOIN sd.order_glass_detail AS ogd
+                          ON ogd.order_id = fc.order_id AND ogd.order_number = fc.order_number AND
+                             ogd.technology_number = fc.technology_number
+                LEFT JOIN (
+                SELECT
+                    fcs.process_id,
+                    fcs.order_number,
+                    COUNT(DISTINCT fcs.technology_number) AS TotalFloors
+                FROM
+                    pp.flow_card AS fcs
+                GROUP BY
+                    fcs.process_id, fcs.order_number
+            ) AS fcss
+                          ON fcss.process_id = fc.process_id AND fcss.order_number = fc.order_number
+        WHERE
+            fc.project_no = #{projectNo}
+        GROUP BY
+            fc.process_id, fc.technology_number
+        ORDER BY
+            fc.process_id, fc.technology_number;
+    </select>
+
+    <!--妯℃嫙璁$畻娴佺▼鍗¤鎯�-->
+    <select id="selectComputeDetailMp">
+        SELECT
+            d.width AS width,
+            d.height AS height,
+            f.quantity AS quantity,
+            d.building_number AS `Storey Number`,
+            d.shape AS shape,
+            round(g.area * f.quantity, 4) AS area,
+            g.icon AS `Label type`
+        FROM
+            pp.flow_card f
+                LEFT JOIN pp.optimize_project p ON f.project_no = p.project_no
+                LEFT JOIN sd.order o ON f.order_id = o.order_id
+                LEFT JOIN sd.order_detail d ON f.order_id = d.order_id AND f.order_number = d.order_number
+                LEFT JOIN sd.order_glass_detail g ON f.order_id = g.order_id AND f.order_number = g.order_number AND f.technology_number = g.technology_number
+                LEFT JOIN sd.product_detail p2 ON d.product_id = p2.prod_id AND f.technology_number = p2.glass_sort
+                LEFT JOIN pp.optimize_project j ON f.project_no = j.project_no
+        WHERE
+            p.state IN (1, 2)
+          AND f.process_id = #{processId}
+    </select>
 </mapper>
\ No newline at end of file

--
Gitblit v1.8.0