From f7649c532163847914e3591236e77c99fb68e1a8 Mon Sep 17 00:00:00 2001
From: gongchunyi <deslre0381@gmail.com>
Date: 星期五, 30 一月 2026 16:42:00 +0800
Subject: [PATCH] Merge branch 'dev_New' of http://114.132.189.42:9002/r/product-inventory-management-after into dev_New

---
 src/main/resources/mapper/measuringinstrumentledger/MeasuringInstrumentLedgerMapper.xml                     |    4 
 src/main/resources/mapper/device/DeviceMaintenanceMapper.xml                                                |    8 +-
 src/main/java/com/ruoyi/production/dto/ProductOrderDto.java                                                 |    8 ++
 src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java                       |   12 ++-
 src/main/resources/mapper/production/SalesLedgerProductionAccountingMapper.xml                              |   36 +++++++++---
 src/main/resources/mapper/stock/StockInventoryMapper.xml                                                    |    6 +
 src/main/java/com/ruoyi/production/dto/SalesLedgerProductionAccountingDto.java                              |   21 +++++-
 src/main/java/com/ruoyi/measuringinstrumentledger/controller/MeasuringInstrumentLedgerRecordController.java |    2 
 src/main/resources/mapper/safe/SafeTrainingDetailsMapper.xml                                                |    2 
 src/main/java/com/ruoyi/production/dto/ProductionProductMainDto.java                                        |   10 ++
 src/main/java/com/ruoyi/stock/dto/StockInRecordDto.java                                                     |    1 
 src/main/java/com/ruoyi/quality/service/QualityTestStandardBindingService.java                              |    2 
 src/main/java/com/ruoyi/production/service/impl/SalesLedgerProductionAccountingServiceImpl.java             |   17 +++++
 src/main/resources/mapper/production/ProductOrderMapper.xml                                                 |    3 
 src/main/java/com/ruoyi/quality/controller/QualityTestStandardBindingController.java                        |    2 
 src/main/resources/static/safe-training.docx                                                                |    0 
 src/main/java/com/ruoyi/device/execl/DeviceRepairExeclDto.java                                              |    2 
 src/main/resources/mapper/production/ProductionProductMainMapper.xml                                        |   10 +++
 src/main/java/com/ruoyi/quality/service/impl/QualityTestStandardBindingServiceImpl.java                     |   16 +++++
 src/main/resources/mapper/quality/QualityTestStandardMapper.xml                                             |    4 
 src/main/resources/mapper/safe/SafeTrainingMapper.xml                                                       |    4 
 21 files changed, 132 insertions(+), 38 deletions(-)

diff --git a/src/main/java/com/ruoyi/device/execl/DeviceRepairExeclDto.java b/src/main/java/com/ruoyi/device/execl/DeviceRepairExeclDto.java
index 694b1d6..9d16e4d 100644
--- a/src/main/java/com/ruoyi/device/execl/DeviceRepairExeclDto.java
+++ b/src/main/java/com/ruoyi/device/execl/DeviceRepairExeclDto.java
@@ -37,7 +37,7 @@
 
     @ApiModelProperty("缁翠慨鏃堕棿")
     @Excel(name = "缁翠慨鏃堕棿", width = 30, dateFormat = "yyyy-MM-dd")
-    private Date maintenanceTime;
+    private LocalDateTime maintenanceTime;
 
     @ApiModelProperty("缁翠慨缁撴灉")
     @Excel(name = "缁翠慨缁撴灉")
diff --git a/src/main/java/com/ruoyi/measuringinstrumentledger/controller/MeasuringInstrumentLedgerRecordController.java b/src/main/java/com/ruoyi/measuringinstrumentledger/controller/MeasuringInstrumentLedgerRecordController.java
index 8c7116e..27663ef 100644
--- a/src/main/java/com/ruoyi/measuringinstrumentledger/controller/MeasuringInstrumentLedgerRecordController.java
+++ b/src/main/java/com/ruoyi/measuringinstrumentledger/controller/MeasuringInstrumentLedgerRecordController.java
@@ -25,7 +25,7 @@
  */
 @RestController
 @Api(tags = "璁¢噺鍣ㄥ叿鍙拌处璁板綍")
-@RequestMapping("/measuringInstrumentLedgerRecord")
+@RequestMapping("Record")
 public class MeasuringInstrumentLedgerRecordController extends BaseController {
 
     @Autowired
diff --git a/src/main/java/com/ruoyi/production/dto/ProductOrderDto.java b/src/main/java/com/ruoyi/production/dto/ProductOrderDto.java
index fe989ba..299cfd7 100644
--- a/src/main/java/com/ruoyi/production/dto/ProductOrderDto.java
+++ b/src/main/java/com/ruoyi/production/dto/ProductOrderDto.java
@@ -1,12 +1,15 @@
 package com.ruoyi.production.dto;
 
 import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
+import com.fasterxml.jackson.annotation.JsonFormat;
 import com.ruoyi.framework.aspectj.lang.annotation.Excel;
 import com.ruoyi.production.pojo.ProductOrder;
 import io.swagger.annotations.ApiModelProperty;
 import lombok.Data;
+import org.springframework.format.annotation.DateTimeFormat;
 
 import java.math.BigDecimal;
+import java.time.LocalDate;
 
 @Data
 @ExcelIgnoreUnannotated
@@ -46,4 +49,9 @@
 
     @ApiModelProperty(value = "浜ゆ湡鍋忓樊")
     private Integer deliveryDaysDiff;
+
+    @ApiModelProperty(value = "浜ゆ湡")
+    @JsonFormat(pattern = "yyyy-MM-dd")
+    @DateTimeFormat(pattern = "yyyy-MM-dd")
+    private LocalDate deliveryDate;
 }
diff --git a/src/main/java/com/ruoyi/production/dto/ProductionProductMainDto.java b/src/main/java/com/ruoyi/production/dto/ProductionProductMainDto.java
index f34124b..5ef224b 100644
--- a/src/main/java/com/ruoyi/production/dto/ProductionProductMainDto.java
+++ b/src/main/java/com/ruoyi/production/dto/ProductionProductMainDto.java
@@ -1,10 +1,12 @@
 package com.ruoyi.production.dto;
 
 import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
+import com.fasterxml.jackson.annotation.JsonFormat;
 import com.ruoyi.framework.aspectj.lang.annotation.Excel;
 import com.ruoyi.production.pojo.ProductionProductMain;
 import io.swagger.annotations.ApiModelProperty;
 import lombok.Data;
+import org.springframework.format.annotation.DateTimeFormat;
 
 import java.math.BigDecimal;
 import java.time.LocalDate;
@@ -30,7 +32,7 @@
 
     @ApiModelProperty(value = "鎶ュ簾鏁伴噺")
     @Excel(name = "鎶ュ簾鏁伴噺")
-    private BigDecimal scrapQty;
+    private BigDecimal scrapQty = BigDecimal.ZERO;
 
     //浜у搧鍚嶇О
     @Excel(name = "浜у搧鍚嶇О")
@@ -48,10 +50,14 @@
     @Excel(name = "閿�鍞悎鍚屽彿")
     private String salesContractNo;
 
-    private LocalDate scheduleDate;
+    @JsonFormat(pattern = "yyyy-MM-dd")
+    @DateTimeFormat(pattern = "yyyy-MM-dd")
+    private LocalDate schedulingDate;
     private String schedulingUserName;
     private String customerName;
     private String process;
     private BigDecimal workHours;
     private BigDecimal wages;
+
+
 }
diff --git a/src/main/java/com/ruoyi/production/dto/SalesLedgerProductionAccountingDto.java b/src/main/java/com/ruoyi/production/dto/SalesLedgerProductionAccountingDto.java
index c86d7bb..8cb4d91 100644
--- a/src/main/java/com/ruoyi/production/dto/SalesLedgerProductionAccountingDto.java
+++ b/src/main/java/com/ruoyi/production/dto/SalesLedgerProductionAccountingDto.java
@@ -1,12 +1,15 @@
 package com.ruoyi.production.dto;
 
 import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
+import com.fasterxml.jackson.annotation.JsonFormat;
 import com.ruoyi.framework.aspectj.lang.annotation.Excel;
 import io.swagger.annotations.ApiModel;
 import io.swagger.annotations.ApiModelProperty;
 import lombok.Data;
+import org.springframework.format.annotation.DateTimeFormat;
 
 import java.math.BigDecimal;
+import java.time.LocalDate;
 
 /**
  * @author :yys
@@ -63,17 +66,27 @@
      */
     @ApiModelProperty(value = "鎺掍骇鏃ユ湡")
     @Excel(name = "鐢熶骇鏃ユ湡")
-    private String schedulingDate;
+    private LocalDate schedulingDate;
 
     @ApiModelProperty(value = "寮�濮嬫椂闂�")
-    private String entryDateStart;
+    @JsonFormat(pattern = "yyyy-MM-dd")
+    @DateTimeFormat(pattern = "yyyy-MM-dd")
+    private LocalDate entryDateStart;
     @ApiModelProperty(value = "缁撴潫鏃堕棿")
-    private String entryDateEnd;
+    @JsonFormat(pattern = "yyyy-MM-dd")
+    @DateTimeFormat(pattern = "yyyy-MM-dd")
+    private LocalDate entryDateEnd;
 
 
     private BigDecimal outputNum;
 
-    private BigDecimal outputRate;
+    private String outputRate;
+
+    @JsonFormat(pattern = "yyyy-MM-dd")
+    @DateTimeFormat(pattern = "yyyy-MM-dd")
+    private LocalDate entryDate;
+
+    private String dateType;
 
 
 }
diff --git a/src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java b/src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java
index 6f71f6b..b2c914b 100644
--- a/src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java
+++ b/src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java
@@ -161,7 +161,7 @@
         //鍚堟牸鏁伴噺=鎶ュ伐鏁伴噺-鎶ュ簾鏁伴噺
         BigDecimal productQty = productionProductOutput.getQuantity().subtract(productionProductOutput.getScrapQty());
         //鍙湁鍚堟牸鏁伴噺>0鎵嶈兘澧炲姞鐩稿簲鏁版嵁
-        if (productQty.compareTo(BigDecimal.ZERO)>0) {
+        if (productQty.compareTo(BigDecimal.ZERO) > 0) {
             /*鏂板璐ㄦ*/
             //瀵瑰簲鐨勮繃绋嬫鎴栬�呭嚭鍘傛
             List<ProductProcessRouteItem> productProcessRouteItems = productProcessRouteItemMapper.selectList(Wrappers.<ProductProcessRouteItem>lambdaQuery().eq(ProductProcessRouteItem::getProductRouteId, productProcessRouteItem.getProductRouteId()));
@@ -190,7 +190,7 @@
                 qualityInspect.setTestStandardId(qualityTestStandard.get(0).getId());
                 qualityInspectMapper.updateById(qualityInspect);
                 qualityTestStandardParamMapper.selectList(Wrappers.<QualityTestStandardParam>lambdaQuery()
-                        .eq(QualityTestStandardParam::getTestStandardId, qualityTestStandard.get(0).getId()))//榛樿鑾峰彇鏈�鏂扮殑
+                                .eq(QualityTestStandardParam::getTestStandardId, qualityTestStandard.get(0).getId()))//榛樿鑾峰彇鏈�鏂扮殑
                         .forEach(qualityTestStandardParam -> {
                             QualityInspectParam param = new QualityInspectParam();
                             BeanUtils.copyProperties(qualityTestStandardParam, param);
@@ -239,8 +239,10 @@
             salesLedgerProductionAccountingMapper.insert(salesLedgerProductionAccounting);
         }
         //濡傛灉鎶ュ簾鏁伴噺>0,闇�瑕佽繘鍏ユ姤搴熺殑搴撳瓨
-        if (dto.getScrapQty().compareTo(BigDecimal.ZERO) > 0) {
-            stockUtils.addUnStock(productModel.getId(), dto.getScrapQty(), StockUnQualifiedRecordTypeEnum.PRODUCTION_SCRAP.getCode(), productionProductMain.getId());
+        if (ObjectUtils.isNotEmpty(dto.getScrapQty())) {
+            if (BigDecimal.ZERO.compareTo(dto.getScrapQty()) > 0) {
+                stockUtils.addUnStock(productModel.getId(), dto.getScrapQty(), StockUnQualifiedRecordTypeEnum.PRODUCTION_SCRAP.getCode(), productionProductMain.getId());
+            }
         }
         return true;
     }
@@ -263,7 +265,7 @@
         productWorkOrderMapper.updateById(productWorkOrder);
         //鍒ゆ柇鏄惁鏄渶鍚庝竴閬撳伐搴�
         List<ProductProcessRouteItem> productProcessRouteItems = productProcessRouteItemMapper.selectList(Wrappers.<ProductProcessRouteItem>lambdaQuery().eq(ProductProcessRouteItem::getProductRouteId, productProcessRouteItem.getProductRouteId()));
-        if (productProcessRouteItem.getDragSort() == productProcessRouteItems.size()){
+        if (productProcessRouteItem.getDragSort() == productProcessRouteItems.size()) {
             ProductOrder productOrder = productOrderMapper.selectById(productWorkOrder.getProductOrderId());
             productOrder.setCompleteQuantity(productOrder.getCompleteQuantity().subtract(productionProductOutput.getQuantity()));
             productOrder.setEndTime(null);
diff --git a/src/main/java/com/ruoyi/production/service/impl/SalesLedgerProductionAccountingServiceImpl.java b/src/main/java/com/ruoyi/production/service/impl/SalesLedgerProductionAccountingServiceImpl.java
index 76ac503..7212d3f 100644
--- a/src/main/java/com/ruoyi/production/service/impl/SalesLedgerProductionAccountingServiceImpl.java
+++ b/src/main/java/com/ruoyi/production/service/impl/SalesLedgerProductionAccountingServiceImpl.java
@@ -3,6 +3,7 @@
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.ruoyi.common.utils.SecurityUtils;
 import com.ruoyi.production.dto.ProductionProductMainDto;
 import com.ruoyi.production.dto.SalesLedgerProductionAccountingDto;
 import com.ruoyi.production.mapper.ProductionProductMainMapper;
@@ -43,11 +44,27 @@
     @Override
     public IPage<SalesLedgerProductionAccountingDto> pageProductionAccounting(SalesLedgerProductionAccountingDto salesLedgerProductionAccountingDto, Page page) {
         // TODO 绠$悊鍛樻煡璇㈡墍鏈夛紝鍏朵粬浜哄彧鑳芥煡鑷繁
+        boolean admin = SecurityUtils.isAdmin(SecurityUtils.getUserId());
+        if (!admin) {
+            salesLedgerProductionAccountingDto.setSchedulingUserName(SecurityUtils.getUsername());
+        }
+        if (salesLedgerProductionAccountingDto.getDateType().equals("month"))  {
+            salesLedgerProductionAccountingDto.setEntryDate(null);
+        }else {
+            salesLedgerProductionAccountingDto.setEntryDateStart(null);
+            salesLedgerProductionAccountingDto.setEntryDateEnd(null);
+        }
         return salesLedgerProductionAccountingMapper.pageProductionAccounting(page, salesLedgerProductionAccountingDto);
     }
 
     @Override
     public IPage<ProductionProductMainDto> listProductionDetails(SalesLedgerProductionAccountingDto salesLedgerProductionAccountingDto, Page page) {
+        if (salesLedgerProductionAccountingDto.getDateType().equals("month"))  {
+            salesLedgerProductionAccountingDto.setEntryDate(null);
+        }else {
+            salesLedgerProductionAccountingDto.setEntryDateStart(null);
+            salesLedgerProductionAccountingDto.setEntryDateEnd(null);
+        }
         return productionProductMainMapper.listProductionDetails(salesLedgerProductionAccountingDto, page);
     }
 
diff --git a/src/main/java/com/ruoyi/quality/controller/QualityTestStandardBindingController.java b/src/main/java/com/ruoyi/quality/controller/QualityTestStandardBindingController.java
index b9c764e..801eaaf 100644
--- a/src/main/java/com/ruoyi/quality/controller/QualityTestStandardBindingController.java
+++ b/src/main/java/com/ruoyi/quality/controller/QualityTestStandardBindingController.java
@@ -34,7 +34,7 @@
      */
     @PostMapping("/add")
     public AjaxResult add(@RequestBody List<QualityTestStandardBinding> qualityTestStandardBindings) {
-        return AjaxResult.success(qualityTestStandardBindingService.saveBatch(qualityTestStandardBindings));
+        return AjaxResult.success(qualityTestStandardBindingService.add(qualityTestStandardBindings));
     }
 
     /**
diff --git a/src/main/java/com/ruoyi/quality/service/QualityTestStandardBindingService.java b/src/main/java/com/ruoyi/quality/service/QualityTestStandardBindingService.java
index a5e6568..9ad4b62 100644
--- a/src/main/java/com/ruoyi/quality/service/QualityTestStandardBindingService.java
+++ b/src/main/java/com/ruoyi/quality/service/QualityTestStandardBindingService.java
@@ -18,4 +18,6 @@
 public interface QualityTestStandardBindingService extends IService<QualityTestStandardBinding> {
 
     List<QualityTestStandardBindingDto> listBinding(Long testStandardId);
+
+    int add(List<QualityTestStandardBinding> qualityTestStandardBindings);
 }
diff --git a/src/main/java/com/ruoyi/quality/service/impl/QualityTestStandardBindingServiceImpl.java b/src/main/java/com/ruoyi/quality/service/impl/QualityTestStandardBindingServiceImpl.java
index 1b372ec..86c6e7f 100644
--- a/src/main/java/com/ruoyi/quality/service/impl/QualityTestStandardBindingServiceImpl.java
+++ b/src/main/java/com/ruoyi/quality/service/impl/QualityTestStandardBindingServiceImpl.java
@@ -1,5 +1,6 @@
 package com.ruoyi.quality.service.impl;
 
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.ruoyi.quality.dto.QualityTestStandardBindingDto;
 import com.ruoyi.quality.pojo.QualityTestStandardBinding;
 import com.ruoyi.quality.mapper.QualityTestStandardBindingMapper;
@@ -28,4 +29,19 @@
     public List<QualityTestStandardBindingDto> listBinding(Long testStandardId) {
         return qualityTestStandardBindingMapper.listBinding(testStandardId);
     }
+
+    @Override
+    public int add(List<QualityTestStandardBinding> qualityTestStandardBindings) {
+        //鍒ゆ柇鏄惁宸茬粡鏈夌粦瀹氳繃鐨勬暟鎹�
+        for (QualityTestStandardBinding qualityTestStandardBinding : qualityTestStandardBindings) {
+            List<QualityTestStandardBinding> testStandardBindings = qualityTestStandardBindingMapper.selectList(Wrappers.<QualityTestStandardBinding>lambdaQuery()
+                    .eq(QualityTestStandardBinding::getTestStandardId, qualityTestStandardBinding.getTestStandardId())
+                    .eq(QualityTestStandardBinding::getProductId, qualityTestStandardBinding.getProductId()));
+            if (testStandardBindings.size() > 0){
+                throw new RuntimeException("璇ヤ骇鍝佸凡缁忕粦瀹氳繃,璇锋鏌�");
+            }
+        }
+        saveBatch(qualityTestStandardBindings);
+        return 0;
+    }
 }
diff --git a/src/main/java/com/ruoyi/stock/dto/StockInRecordDto.java b/src/main/java/com/ruoyi/stock/dto/StockInRecordDto.java
index 1aed75c..9f47fd6 100644
--- a/src/main/java/com/ruoyi/stock/dto/StockInRecordDto.java
+++ b/src/main/java/com/ruoyi/stock/dto/StockInRecordDto.java
@@ -25,4 +25,5 @@
 
     //鐜板瓨閲�
     private String currentStock;
+
 }
diff --git a/src/main/resources/mapper/device/DeviceMaintenanceMapper.xml b/src/main/resources/mapper/device/DeviceMaintenanceMapper.xml
index 7046102..2ed16a4 100644
--- a/src/main/resources/mapper/device/DeviceMaintenanceMapper.xml
+++ b/src/main/resources/mapper/device/DeviceMaintenanceMapper.xml
@@ -38,11 +38,11 @@
             <if test="deviceMaintenanceDto.maintenanceActuallyName != null">
                 and dm.maintenance_actually_name like concat('%',#{deviceMaintenanceDto.maintenanceActuallyName},'%')
             </if>
-            <if test="deviceMaintenanceDto.maintenancePlanTimeReq != null">
-                and dm.maintenance_plan_time like concat('%',#{deviceMaintenanceDto.maintenancePlanTimeReq},'%')
+            <if test="deviceMaintenanceDto.maintenancePlanTime != null">
+                and dm.maintenance_plan_time like concat('%',#{deviceMaintenanceDto.maintenancePlanTime},'%')
             </if>
-            <if test="deviceMaintenanceDto.maintenanceActuallyTimeReq != null">
-                and dm.maintenance_actually_time like concat('%',#{deviceMaintenanceDto.maintenanceActuallyTimeReq},'%')
+            <if test="deviceMaintenanceDto.maintenanceActuallyTime != null">
+                and dm.maintenance_actually_time like concat('%',#{deviceMaintenanceDto.maintenanceActuallyTime},'%')
             </if>
             <if test="deviceMaintenanceDto.maintenanceActuallyTime != null">
                 and dm.maintenance_actually_time >= str_to_date(#{deviceMaintenanceDto.maintenanceActuallyTime}, '%Y-%m-%d')
diff --git a/src/main/resources/mapper/measuringinstrumentledger/MeasuringInstrumentLedgerMapper.xml b/src/main/resources/mapper/measuringinstrumentledger/MeasuringInstrumentLedgerMapper.xml
index 705d516..e4200af 100644
--- a/src/main/resources/mapper/measuringinstrumentledger/MeasuringInstrumentLedgerMapper.xml
+++ b/src/main/resources/mapper/measuringinstrumentledger/MeasuringInstrumentLedgerMapper.xml
@@ -15,7 +15,7 @@
         next_date,
         record_date,
         CASE
-        WHEN next_date &gt;=  DATE_FORMAT(now(),'%Y-%m-%d') THEN 1
+        WHEN most_date &gt;=  DATE_FORMAT(now(),'%Y-%m-%d') THEN 1
         ELSE 2
         END AS status,
         create_user,
@@ -56,4 +56,4 @@
         </where>
         ORDER BY update_time DESC
     </select>
-</mapper>
\ No newline at end of file
+</mapper>
diff --git a/src/main/resources/mapper/production/ProductOrderMapper.xml b/src/main/resources/mapper/production/ProductOrderMapper.xml
index 4d11daf..227e707 100644
--- a/src/main/resources/mapper/production/ProductOrderMapper.xml
+++ b/src/main/resources/mapper/production/ProductOrderMapper.xml
@@ -22,7 +22,8 @@
         ppr.process_route_code,
         pb.bom_no,
         ROUND(po.complete_quantity / po.quantity * 100, 2) AS completionStatus,
-        DATEDIFF(sl.delivery_date, CURDATE()) AS delivery_days_diff
+        DATEDIFF(sl.delivery_date, CURDATE()) AS delivery_days_diff,
+        sl.delivery_date
         from product_order po
         left join sales_ledger sl on po.sales_ledger_id = sl.id
         left join sales_ledger_product slp on po.sale_ledger_product_id = slp.id
diff --git a/src/main/resources/mapper/production/ProductionProductMainMapper.xml b/src/main/resources/mapper/production/ProductionProductMainMapper.xml
index aeb4230..1cfc0d8 100644
--- a/src/main/resources/mapper/production/ProductionProductMainMapper.xml
+++ b/src/main/resources/mapper/production/ProductionProductMainMapper.xml
@@ -63,7 +63,7 @@
         sl.sales_contract_no,
         sl.customer_name,
         p.product_name,
-        pm.model,
+        pm.model as product_model_name,
         pm.unit,
         slpa.process,
         ppo.quantity,
@@ -83,6 +83,14 @@
             <if test="ew.schedulingUserName != null and ew.schedulingUserName !=''">
                 and slpa.scheduling_user_name = #{ew.schedulingUserName}
             </if>
+            <if test="ew.entryDate != null " >
+                and slpa.scheduling_date >= #{ew.entryDate}
+                and slpa.scheduling_date &lt; DATE_ADD(#{ew.entryDate}, INTERVAL 1 DAY)
+            </if>
+            <if test="ew.entryDateStart != null and ew.entryDateEnd != null" >
+                and slpa.scheduling_date >= #{ew.entryDateStart}
+                and slpa.scheduling_date &lt; date_add(#{ew.entryDateEnd}, INTERVAL 1 DAY)
+            </if>
         </where>
     </select>
 
diff --git a/src/main/resources/mapper/production/SalesLedgerProductionAccountingMapper.xml b/src/main/resources/mapper/production/SalesLedgerProductionAccountingMapper.xml
index 42090a7..31e95de 100644
--- a/src/main/resources/mapper/production/SalesLedgerProductionAccountingMapper.xml
+++ b/src/main/resources/mapper/production/SalesLedgerProductionAccountingMapper.xml
@@ -53,18 +53,36 @@
     <select id="pageProductionAccounting"
             resultType="com.ruoyi.production.dto.SalesLedgerProductionAccountingDto">
         SELECT
-            slpa.scheduling_user_id,
-            slpa.scheduling_user_name,
-               sum(ppout.quantity) as output_num,
-               sum(slpa.finished_num * work_hours) as  wages,
-               SUM(slpa.finished_num) / SUM(ppout.quantity) as output_rate
+        slpa.scheduling_user_id,
+        slpa.scheduling_user_name,
+        sum(ppout.quantity) as output_num,
+        sum(slpa.finished_num * work_hours) as wages,
+        CONCAT(
+        ROUND(
+        CASE
+        WHEN SUM(ppout.quantity) = 0 OR SUM(ppout.quantity) IS NULL THEN 0
+        ELSE SUM(slpa.finished_num) * 100.0 / SUM(ppout.quantity)
+        END,
+        2
+        ),
+        '%'
+        ) as output_rate
         FROM sales_ledger_production_accounting slpa
-                 LEFT JOIN production_product_main ppm ON slpa.sales_ledger_work_id = ppm.id
-                 LEFT JOIN production_product_output ppout ON ppm.id = ppout.product_main_id
+        LEFT JOIN production_product_main ppm ON slpa.sales_ledger_work_id = ppm.id
+        LEFT JOIN production_product_output ppout ON ppm.id = ppout.product_main_id
         <where>
-            <if test="ew.schedulingUserName != null and ew.schedulingUserName !=''" >
-                and slpa.scheduling_user_name  = #{ew.schedulingUserName}
+            <if test="ew.schedulingUserName != null and ew.schedulingUserName !=''">
+                and slpa.scheduling_user_name = #{ew.schedulingUserName}
             </if>
+            <if test="ew.entryDate != null ">
+                and slpa.scheduling_date >= #{ew.entryDate}
+                and slpa.scheduling_date &lt; DATE_ADD(DATE(#{ew.entryDate}), INTERVAL 1 DAY)
+            </if>
+            <if test="ew.entryDateStart != null and ew.entryDateEnd != null">
+                and slpa.scheduling_date >= #{ew.entryDateStart}
+                and slpa.scheduling_date &lt; DATE_ADD(DATE(#{ew.entryDateEnd}), INTERVAL 1 DAY)
+            </if>
+
         </where>
         GROUP BY slpa.scheduling_user_name
 
diff --git a/src/main/resources/mapper/quality/QualityTestStandardMapper.xml b/src/main/resources/mapper/quality/QualityTestStandardMapper.xml
index b9ad8ed..5c20733 100644
--- a/src/main/resources/mapper/quality/QualityTestStandardMapper.xml
+++ b/src/main/resources/mapper/quality/QualityTestStandardMapper.xml
@@ -13,10 +13,10 @@
         <if test="c.standardName != null and c.standardName != '' ">
             AND standard_name like concat('%',#{c.standardName},'%')
         </if>
-        <if test="c.state != null and c.state != '' ">
+        <if test="c.state != null ">
             AND state =#{c.state}
         </if>
-        <if test="c.inspectType != null and c.inspectType != '' ">
+        <if test="c.inspectType != null ">
             AND inspect_type =#{c.inspectType}
         </if>
     </select>
diff --git a/src/main/resources/mapper/safe/SafeTrainingDetailsMapper.xml b/src/main/resources/mapper/safe/SafeTrainingDetailsMapper.xml
index c96d711..7300cf0 100644
--- a/src/main/resources/mapper/safe/SafeTrainingDetailsMapper.xml
+++ b/src/main/resources/mapper/safe/SafeTrainingDetailsMapper.xml
@@ -30,7 +30,7 @@
                  left join safe_training st on std.safe_training_id = st.id
         where std.user_id = #{c.userId}
         <if test="c.trainingDate != null">
-            and st.training_date = #{c.trainingDate}
+            and st.training_date = date_format(#{c.trainingDate},'%Y%m%d')
         </if>
     </select>
 
diff --git a/src/main/resources/mapper/safe/SafeTrainingMapper.xml b/src/main/resources/mapper/safe/SafeTrainingMapper.xml
index 1ae5159..dac3417 100644
--- a/src/main/resources/mapper/safe/SafeTrainingMapper.xml
+++ b/src/main/resources/mapper/safe/SafeTrainingMapper.xml
@@ -41,8 +41,8 @@
         <if test="c.placeTraining != null and c.placeTraining != ''">
             and st.place_training like concat('%', #{c.placeTraining}, '%')
         </if>
-        <if test="c.trainingDate != null and c.trainingDate != ''">
-            and st.training_date = #{c.trainingDate}
+        <if test="c.trainingDate != null ">
+            and st.training_date = date_format(#{c.trainingDate},'%Y%m%d')
         </if>
     </select>
     <select id="getSafeTraining" resultType="com.ruoyi.safe.dto.SafeTrainingDto">
diff --git a/src/main/resources/mapper/stock/StockInventoryMapper.xml b/src/main/resources/mapper/stock/StockInventoryMapper.xml
index 79b08cd..7fe1f4f 100644
--- a/src/main/resources/mapper/stock/StockInventoryMapper.xml
+++ b/src/main/resources/mapper/stock/StockInventoryMapper.xml
@@ -91,15 +91,17 @@
         </if>
     </select>
     <select id="stockInventoryPage" resultType="com.ruoyi.stock.dto.StockInRecordDto">
-        select sir.*,si.qualitity,
+        select sir.*,si.qualitity as current_stock,
         pm.model,
         pm.unit,
-        p.product_name
+        p.product_name,
+        su.nick_name as create_by
         from
         stock_in_record sir
         left join stock_inventory si on sir.product_model_id = si.product_model_id
         left join product_model pm on sir.product_model_id = pm.id
         left join product p on pm.product_id = p.id
+        left join sys_user su on sir.create_user = su.user_id
         <where>
             <if test="ew.reportDate != null">
                 and sir.create_time >= #{ew.reportDate}
diff --git a/src/main/resources/static/safe-training.docx b/src/main/resources/static/safe-training.docx
index 0bc1d64..74e9150 100644
--- a/src/main/resources/static/safe-training.docx
+++ b/src/main/resources/static/safe-training.docx
Binary files differ

--
Gitblit v1.9.3