From 0dd70afb7815d34a02ba7f5cd4f0ad8457072607 Mon Sep 17 00:00:00 2001
From: maven <2163098428@qq.com>
Date: 星期五, 09 一月 2026 10:01:31 +0800
Subject: [PATCH] yys  修改bug

---
 src/main/java/com/ruoyi/purchase/service/impl/TicketRegistrationServiceImpl.java |   21 +++++++++++++--------
 src/main/java/com/ruoyi/purchase/service/impl/PurchaseLedgerServiceImpl.java     |    2 +-
 2 files changed, 14 insertions(+), 9 deletions(-)

diff --git a/src/main/java/com/ruoyi/purchase/service/impl/PurchaseLedgerServiceImpl.java b/src/main/java/com/ruoyi/purchase/service/impl/PurchaseLedgerServiceImpl.java
index 2d6eacb..97e647f 100644
--- a/src/main/java/com/ruoyi/purchase/service/impl/PurchaseLedgerServiceImpl.java
+++ b/src/main/java/com/ruoyi/purchase/service/impl/PurchaseLedgerServiceImpl.java
@@ -113,7 +113,7 @@
     @Override
     @Transactional(rollbackFor = Exception.class)
     public int addOrEditPurchase(PurchaseLedgerDto purchaseLedgerDto) throws IOException {
-        if(StringUtils.isNotBlank(purchaseLedgerDto.getPurchaseContractNumber())){
+        if(purchaseLedgerDto.getId() == null && StringUtils.isNotBlank(purchaseLedgerDto.getPurchaseContractNumber())){
             List<PurchaseLedger> purchaseLedgers = purchaseLedgerMapper.selectList(new LambdaQueryWrapper<PurchaseLedger>()
                     .eq(PurchaseLedger::getPurchaseContractNumber, purchaseLedgerDto.getPurchaseContractNumber()));
             if(CollectionUtils.isNotEmpty(purchaseLedgers)){
diff --git a/src/main/java/com/ruoyi/purchase/service/impl/TicketRegistrationServiceImpl.java b/src/main/java/com/ruoyi/purchase/service/impl/TicketRegistrationServiceImpl.java
index 610786b..119664e 100644
--- a/src/main/java/com/ruoyi/purchase/service/impl/TicketRegistrationServiceImpl.java
+++ b/src/main/java/com/ruoyi/purchase/service/impl/TicketRegistrationServiceImpl.java
@@ -52,6 +52,7 @@
 import java.util.List;
 import java.util.Map;
 import java.util.UUID;
+import java.util.concurrent.atomic.AtomicBoolean;
 import java.util.stream.Collectors;
 
 /**
@@ -420,19 +421,20 @@
 
         // 鎵归噺鏇存柊锛堥渶瑕� MyBatis 鎻愪緵鎵归噺鏇存柊鏂规硶锛�
         if (!updateList.isEmpty()) {
+            AtomicBoolean isUpdated = new AtomicBoolean(true);
             updateList.forEach(product -> {
                 // 闈炵┖鏍¢獙锛屼换涓�瀛楁涓虹┖鍒欐姏鍑哄紓甯�
-                if (product.getQuantity() == null) {
-                    throw new BaseException("鏁伴噺涓嶈兘涓虹┖");
+                if (product.getQuantity() != null) {
+                    isUpdated.set(false);
                 }
-                if (product.getTicketsNum() == null) {
-                    throw new BaseException("宸插紑绁ㄦ暟閲忎笉鑳戒负绌�");
+                if (product.getTicketsNum() != null) {
+                    isUpdated.set(false);
                 }
-                if (product.getTaxInclusiveTotalPrice() == null) {
-                    throw new BaseException("鍚◣鎬讳环涓嶈兘涓虹┖");
+                if (product.getTaxInclusiveTotalPrice() != null) {
+                    isUpdated.set(false);
                 }
-                if (product.getTicketsAmount() == null) {
-                    throw new BaseException("鏈鏉ョエ閲戦(鍏�)涓嶈兘涓虹┖");
+                if (product.getTicketsAmount() != null) {
+                    isUpdated.set(false);
                 }
 
                 // 璁$畻 futureTickets锛堢洿鎺ヤ娇鐢� BigDecimal 璁$畻锛岄伩鍏嶇簿搴︿涪澶憋級
@@ -450,6 +452,9 @@
                 product.setType(type);
                 salesLedgerProductMapper.updateById(product);
             });
+            if(isUpdated.get()){
+                throw new RuntimeException("鏉ョエ鏁颁笉鍙叏閮ㄤ负绌�");
+            }
         }
     }
 

--
Gitblit v1.9.3