From 620bb4712a31791231c4381581f0f60088f079fe Mon Sep 17 00:00:00 2001
From: 云 <2163098428@qq.com>
Date: 星期三, 27 五月 2026 14:03:45 +0800
Subject: [PATCH] Merge branch 'refs/heads/dev_New_pro' into dev_宁夏_英泽防锈

---
 src/main/resources/mapper/stock/StockInRecordMapper.xml |   92 +++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 90 insertions(+), 2 deletions(-)

diff --git a/src/main/resources/mapper/stock/StockInRecordMapper.xml b/src/main/resources/mapper/stock/StockInRecordMapper.xml
index 55e57a3..a3bf3f9 100644
--- a/src/main/resources/mapper/stock/StockInRecordMapper.xml
+++ b/src/main/resources/mapper/stock/StockInRecordMapper.xml
@@ -19,11 +19,96 @@
         p.product_name as product_name,
         pm.model,
         pm.unit,
-        u.nick_name as createBy
+        u.nick_name as createBy,
+        CASE
+            WHEN #{params.topParentProductId} = 278 AND TRIM(sir.record_type) = '7' THEN
+                COALESCE(pl_by_product.purchase_contract_number, pl_direct.purchase_contract_number)
+            WHEN #{params.topParentProductId} = 278 AND TRIM(sir.record_type) = '10' THEN
+                pl_by_quality.purchase_contract_number
+            WHEN #{params.topParentProductId} = 276 THEN
+                CASE
+                    WHEN TRIM(sir.record_type) IN ('14', '15') THEN
+                        sl_return.sales_contract_no
+                    WHEN TRIM(sir.record_type) IN ('2', '5') THEN
+                        COALESCE(po_sales_main.sales_contract_no, po_main.nps_no)
+                    WHEN TRIM(sir.record_type) = '6' THEN
+                        COALESCE(po_sales_qi.sales_contract_no, po_qi.nps_no)
+                    WHEN TRIM(sir.record_type) IN ('4', '11') THEN
+                        COALESCE(po_sales_uq.sales_contract_no, po_uq.nps_no)
+                    WHEN TRIM(sir.record_type) IN ('20', '22') THEN
+                        COALESCE(po_sales_pick.sales_contract_no, po_pick.nps_no)
+                    ELSE NULL
+                END
+            ELSE NULL
+        END AS sourceOrderNo
         FROM stock_in_record as sir
         LEFT JOIN product_model as pm on sir.product_model_id = pm.id
         LEFT JOIN product as p on pm.product_id = p.id
         LEFT JOIN sys_user as u on sir.create_user = u.user_id
+        LEFT JOIN quality_inspect as qi_purchase on TRIM(sir.record_type) = '10' and sir.record_id = qi_purchase.id
+        LEFT JOIN sales_ledger_product as slp on TRIM(sir.record_type) = '7' and slp.id = sir.record_id and slp.type = 2
+        LEFT JOIN purchase_ledger as pl_by_product on TRIM(sir.record_type) = '7' and pl_by_product.id = slp.sales_ledger_id
+        LEFT JOIN purchase_ledger as pl_direct on TRIM(sir.record_type) = '7' and pl_direct.id = sir.record_id
+        LEFT JOIN purchase_ledger as pl_by_quality on TRIM(sir.record_type) = '10' and pl_by_quality.id = qi_purchase.purchase_ledger_id
+
+        LEFT JOIN production_product_main as ppm_main on TRIM(sir.record_type) IN ('2', '5') and sir.record_id = ppm_main.id
+        LEFT JOIN production_operation_task as pot_main on ppm_main.production_operation_task_id = pot_main.id
+        LEFT JOIN production_order as po_main on pot_main.production_order_id = po_main.id
+        LEFT JOIN (
+            select po2.id as production_order_id,
+                   group_concat(distinct sl2.sales_contract_no order by sl2.sales_contract_no separator ',') as sales_contract_no
+            from production_order po2
+                     left join production_plan pp2
+                               on find_in_set(pp2.id, replace(replace(replace(po2.production_plan_ids, '[', ''), ']', ''), ' ', '')) > 0
+                     left join sales_ledger sl2 on sl2.id = pp2.sales_ledger_id
+            group by po2.id
+        ) as po_sales_main on po_sales_main.production_order_id = po_main.id
+
+        LEFT JOIN quality_inspect as qi_prod on TRIM(sir.record_type) = '6' and sir.record_id = qi_prod.id
+        LEFT JOIN production_product_main as ppm_qi on qi_prod.product_main_id = ppm_qi.id
+        LEFT JOIN production_operation_task as pot_qi on ppm_qi.production_operation_task_id = pot_qi.id
+        LEFT JOIN production_order as po_qi on pot_qi.production_order_id = po_qi.id
+        LEFT JOIN (
+            select po2.id as production_order_id,
+                   group_concat(distinct sl2.sales_contract_no order by sl2.sales_contract_no separator ',') as sales_contract_no
+            from production_order po2
+                     left join production_plan pp2
+                               on find_in_set(pp2.id, replace(replace(replace(po2.production_plan_ids, '[', ''), ']', ''), ' ', '')) > 0
+                     left join sales_ledger sl2 on sl2.id = pp2.sales_ledger_id
+            group by po2.id
+        ) as po_sales_qi on po_sales_qi.production_order_id = po_qi.id
+
+        LEFT JOIN quality_unqualified as qu on TRIM(sir.record_type) IN ('4', '11') and sir.record_id = qu.id
+        LEFT JOIN quality_inspect as qi_uq on qu.inspect_id = qi_uq.id
+        LEFT JOIN production_product_main as ppm_uq on qi_uq.product_main_id = ppm_uq.id
+        LEFT JOIN production_operation_task as pot_uq on ppm_uq.production_operation_task_id = pot_uq.id
+        LEFT JOIN production_order as po_uq on pot_uq.production_order_id = po_uq.id
+        LEFT JOIN (
+            select po2.id as production_order_id,
+                   group_concat(distinct sl2.sales_contract_no order by sl2.sales_contract_no separator ',') as sales_contract_no
+            from production_order po2
+                     left join production_plan pp2
+                               on find_in_set(pp2.id, replace(replace(replace(po2.production_plan_ids, '[', ''), ']', ''), ' ', '')) > 0
+                     left join sales_ledger sl2 on sl2.id = pp2.sales_ledger_id
+            group by po2.id
+        ) as po_sales_uq on po_sales_uq.production_order_id = po_uq.id
+
+        LEFT JOIN production_order_pick as pop on TRIM(sir.record_type) IN ('20', '22') and sir.record_id = pop.id
+        LEFT JOIN production_order as po_pick on pop.production_order_id = po_pick.id
+        LEFT JOIN (
+            select po2.id as production_order_id,
+                   group_concat(distinct sl2.sales_contract_no order by sl2.sales_contract_no separator ',') as sales_contract_no
+            from production_order po2
+                     left join production_plan pp2
+                               on find_in_set(pp2.id, replace(replace(replace(po2.production_plan_ids, '[', ''), ']', ''), ' ', '')) > 0
+                     left join sales_ledger sl2 on sl2.id = pp2.sales_ledger_id
+            group by po2.id
+        ) as po_sales_pick on po_sales_pick.production_order_id = po_pick.id
+
+        LEFT JOIN return_sale_product as rsp on TRIM(sir.record_type) IN ('14', '15') and sir.record_id = rsp.id
+        LEFT JOIN return_management as rm on rsp.return_management_id = rm.id
+        LEFT JOIN shipping_info as si_return on rm.shipping_id = si_return.id
+        LEFT JOIN sales_ledger as sl_return on si_return.sales_ledger_id = sl_return.id
         <where>
             <if test="params.timeStr != null and params.timeStr != ''">
                 and sir.create_time like concat('%',#{params.timeStr},'%')
@@ -93,7 +178,7 @@
             LEFT JOIN purchase_ledger pl
             ON pl.id = IF(sir.record_type = 7, sir.record_id, qi.purchase_ledger_id)
             -- 浜у搧鍏宠仈涓嶅姩
-            LEFT JOIN sales_ledger_product slp ON pl.id = slp.product_id
+            LEFT JOIN sales_ledger_product slp ON pl.id = slp.sales_ledger_id
             LEFT JOIN product_model pm ON sir.product_model_id = pm.id
             LEFT JOIN product p ON pm.product_id = p.id
             -- 鏉′欢
@@ -102,6 +187,9 @@
         <if test="req.inboundBatches != null and req.inboundBatches != ''">
             AND sir.inbound_batches LIKE CONCAT('%',#{req.inboundBatches},'%')
         </if>
+        <if test="req.supplierId != null">
+            AND pl.supplier_id = #{req.supplierId}
+        </if>
         <if test="req.supplierName != null and req.supplierName != ''">
             AND pl.supplier_name LIKE CONCAT('%',#{req.supplierName},'%')
         </if>

--
Gitblit v1.9.3