Bläddra i källkod

fix(quartz):优化门禁记录同步任务并修复日期格式问题

- 调整定时任务执行间隔从7200秒到30秒
- 替换forEach循环为增强for循环提高性能-修复日期解析格式不一致问题,统一使用"yyyy-MM-dd HH:mm:ss"
- 增加日期格式化处理,确保日期字符串正确匹配
- 注释掉无用的日志打印代码- 添加LocalDateTime导入语句支持新日期处理逻辑
wzq 1 vecka sedan
förälder
incheckning
7c7cce91c8

+ 1 - 0
national-motion-module-system/national-motion-system-biz/src/main/java/org/jeecg/modules/app/service/impl/OrderServiceImpl.java

@@ -619,6 +619,7 @@ public class OrderServiceImpl extends ServiceImpl<AppOrderMapper, AppOrder> impl
                                 .setOrderStatus(1)
                                 .setQuantity(1)
                                 .setFamilyUserId(id)
+                                .setSiteId(appOrder.getAddressSiteId())
                                 .setUserName(familyMembers.getFullName())
                                 .setUserPhone(familyMembers.getPhone())
                                 .setStatus(CommonConstant.STATUS_0_INT)

+ 17 - 6
national-motion-module-system/national-motion-system-biz/src/main/java/org/jeecg/modules/quartz/job/OrTeachingJobService.java

@@ -1,6 +1,7 @@
 package org.jeecg.modules.quartz.job;
 
 
+import cn.hutool.core.date.DateUtil;
 import com.alibaba.fastjson.JSON;
 import com.alibaba.fastjson.JSONArray;
 import com.alibaba.fastjson.JSONObject;
@@ -26,6 +27,7 @@ import org.springframework.transaction.annotation.Transactional;
 import javax.annotation.Resource;
 import java.text.ParseException;
 import java.text.SimpleDateFormat;
+import java.time.LocalDateTime;
 import java.util.ArrayList;
 import java.util.Date;
 import java.util.List;
@@ -236,13 +238,12 @@ public class OrTeachingJobService {
      * @Param
      * @return
      **/
-    @Scheduled(fixedDelay = 7200000)
+    @Scheduled(fixedDelay = 30000)
 //    @Scheduled(cron = "0 0 23 * * ?")
     public void synchronousDoorOpeningAndClosingRecords(){
         try {
             List<DoorRecordDTO> allRecords = fetchAllDoorRecords();
-            allRecords.forEach(data -> {
-//                log.info("提取数据: {}", data);
+            for (DoorRecordDTO data : allRecords) {
                 if(null == appGmtInfoMapper.selectOne(Wrappers.<AppGmtInfo>lambdaQuery().eq(AppGmtInfo::getOriginId, data.getOriginId()).last("LIMIT 1"))){
                     String siteId = appDeviceMapper.selectOne(Wrappers.<AppDevice>lambdaQuery()
                             .eq(AppDevice::getDeviceSerial, data.getDeviceSerial().split("-")[0])).getSiteId();
@@ -259,9 +260,15 @@ public class OrTeachingJobService {
                             .setUpdateTime(new Date())
                             .setDeviceSerialNo(data.getDeviceSerial()));
                     //查询相关日期学校子订单
-                    Date date = DateUtils.str2Date(data.getGmtCreate(), new SimpleDateFormat("yyyy-MM-dd"));
+                    // 定义格式化模板
+                    SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
+
+                    // 格式化输出
+                    Date date = DateUtils.str2Date(data.getGmtCreate(), new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"));
+                    String formattedDate = sdf.format(date);
+
                     List<AppOrderProInfo> orderProInfoList = appOrderProInfoService.list(Wrappers.lambdaQuery(AppOrderProInfo.class)
-                            .eq(AppOrderProInfo::getUseDateStr, date)
+                            .eq(AppOrderProInfo::getUseDateStr, formattedDate)
                             .eq(AppOrderProInfo::getFamilyUserId, data.getEmployeeNo())
                             .eq(AppOrderProInfo::getSiteId, siteId)
                             .eq(AppOrderProInfo::getType, CommonConstant.ORDER_PRO_INFO_TYPE_0)
@@ -275,7 +282,11 @@ public class OrTeachingJobService {
                         }
                     }
                 }
-            });
+            }
+//            allRecords.forEach(data -> {
+////                log.info("提取数据: {}", data);
+//
+//            });
         } catch (Exception e) {
             log.error("处理门禁记录失败", e);
         }