From 2bc90e242eceb83d9aa80d48ea9f991c0f9b99c6 Mon Sep 17 00:00:00 2001
From: eight <641137800@qq.com>
Date: 星期四, 12 十二月 2024 19:47:57 +0800
Subject: [PATCH] 工位选择界面 诊室按照room id排序

---
 jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/dal/mysql/jobrecord/JobRecordMapper.java |   27 +++++++++++++++++++++++++--
 1 files changed, 25 insertions(+), 2 deletions(-)

diff --git a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/dal/mysql/jobrecord/JobRecordMapper.java b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/dal/mysql/jobrecord/JobRecordMapper.java
index c18d63d..bc3d90b 100644
--- a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/dal/mysql/jobrecord/JobRecordMapper.java
+++ b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/dal/mysql/jobrecord/JobRecordMapper.java
@@ -1,13 +1,17 @@
 package cn.lihu.jh.module.ecg.dal.mysql.jobrecord;
 
+import java.time.LocalDateTime;
 import java.util.*;
 
 import cn.lihu.jh.framework.common.pojo.PageResult;
 import cn.lihu.jh.framework.mybatis.core.query.LambdaQueryWrapperX;
 import cn.lihu.jh.framework.mybatis.core.mapper.BaseMapperX;
 import cn.lihu.jh.module.ecg.dal.dataobject.jobrecord.JobRecordDO;
+import cn.lihu.jh.module.ecg.dal.dataobject.jobrecord.JobRecordStatisticDO;
 import org.apache.ibatis.annotations.Mapper;
 import cn.lihu.jh.module.ecg.controller.admin.jobrecord.vo.*;
+import org.apache.ibatis.annotations.Param;
+import org.apache.ibatis.annotations.Select;
 
 /**
  * 宸ヤ綔璁板綍 Mapper
@@ -19,7 +23,8 @@
 
     default PageResult<JobRecordDO> selectPage(JobRecordPageReqVO reqVO) {
         return selectPage(reqVO, new LambdaQueryWrapperX<JobRecordDO>()
-                .eqIfPresent(JobRecordDO::getJobType, reqVO.getJobType())
+                //.eqIfPresent(JobRecordDO::getJobType, reqVO.getJobType())
+                .inIfPresent(JobRecordDO::getJobType, reqVO.getJobType())
                 .eqIfPresent(JobRecordDO::getDocId, reqVO.getDocId())
                 .likeIfPresent(JobRecordDO::getDocName, reqVO.getDocName())
                 .eqIfPresent(JobRecordDO::getDevId, reqVO.getDevId())
@@ -29,7 +34,25 @@
                 .eqIfPresent(JobRecordDO::getSummary, reqVO.getSummary())
                 .eqIfPresent(JobRecordDO::getRemark, reqVO.getRemark())
                 .betweenIfPresent(JobRecordDO::getCreateTime, reqVO.getCreateTime())
+                .eqIfPresent(JobRecordDO::getRentId, reqVO.getRentId())
                 .orderByDesc(JobRecordDO::getId));
     }
 
-}
\ No newline at end of file
+    @Select("<script> " +
+            "SELECT * FROM lihu.job_record " +
+            " where rent_id=#{rentId} and doc_id=#{docId} and job_type in (" +
+                    " <foreach collection='jobTypeList' separator=',' item='jobType'>" +
+                    "  #{jobType} " +
+                    " </foreach> )" +
+            " limit 1;" +
+            " </script>")
+    JobRecordDO selectByRentIdDocId(@Param("rentId") Long rentId, @Param("docId") Long docId, @Param("jobTypeList") List<Integer> jobTypeList );
+
+    @Select("SELECT count(1) FROM lihu.job_record where pat_id=#{patId} and TO_DAYS(job_time)=TO_DAYS(#{jobTime}) and job_type=#{jobType} ")
+    Integer getPatientJobNum(@Param("patId") String patId, @Param("jobTime") LocalDateTime jobTime, @Param("jobType") Integer jobType );
+
+    @Select("select year(job_time) as year, month(job_time) as month, doc_id, doc_name, job_type, count(1) as job_count from lihu.job_record " +
+            "where job_time >= #{jobTimeFrom} and job_time < #{jobTimeTo} \n" +
+            "group by year(job_time), month(job_time), doc_id, job_type;")
+    List<JobRecordStatisticDO> getJobStatistic(@Param("jobTimeFrom") LocalDateTime jobTimeFrom, @Param("jobTimeTo") LocalDateTime jobTimeTo);
+}

--
Gitblit v1.9.3