查询当日就诊数据
This commit is contained in:
		| @@ -73,4 +73,14 @@ public interface IOutpatientRegistrationAppService { | |||||||
|      */ |      */ | ||||||
|     R<?> saveRegister(OutpatientRegistrationAddParam outpatientRegistrationAddParam); |     R<?> saveRegister(OutpatientRegistrationAddParam outpatientRegistrationAddParam); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询当日就诊数据 | ||||||
|  |      * | ||||||
|  |      * @param searchKey 模糊查询关键字 | ||||||
|  |      * @param pageNo 当前页 | ||||||
|  |      * @param pageSize 每页多少条 | ||||||
|  |      * @return 当日就诊数据 | ||||||
|  |      */ | ||||||
|  |     IPage<CurrentDayEncounterDto> getCurrentDayEncounter(String searchKey, Integer pageNo, Integer pageSize); | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -7,8 +7,6 @@ import java.util.stream.Collectors; | |||||||
|  |  | ||||||
| import javax.annotation.Resource; | import javax.annotation.Resource; | ||||||
|  |  | ||||||
| import com.openhis.common.enums.*; |  | ||||||
| import com.openhis.common.enums.PractitionerRole; |  | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||||
| @@ -26,6 +24,8 @@ import com.openhis.clinical.domain.ConditionDefinition; | |||||||
| import com.openhis.clinical.mapper.ConditionDefinitionMapper; | import com.openhis.clinical.mapper.ConditionDefinitionMapper; | ||||||
| import com.openhis.common.constant.CommonConstants; | import com.openhis.common.constant.CommonConstants; | ||||||
| import com.openhis.common.constant.PromptMsgConstant; | import com.openhis.common.constant.PromptMsgConstant; | ||||||
|  | import com.openhis.common.enums.*; | ||||||
|  | import com.openhis.common.enums.PractitionerRole; | ||||||
| import com.openhis.common.utils.EnumUtils; | import com.openhis.common.utils.EnumUtils; | ||||||
| import com.openhis.common.utils.HisPageUtils; | import com.openhis.common.utils.HisPageUtils; | ||||||
| import com.openhis.common.utils.HisQueryUtils; | import com.openhis.common.utils.HisQueryUtils; | ||||||
| @@ -268,4 +268,30 @@ public class IOutpatientRegistrationAppServiceImpl implements IOutpatientRegistr | |||||||
|         return R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00004, new Object[] {"挂号"})); |         return R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00004, new Object[] {"挂号"})); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询当日就诊数据 | ||||||
|  |      * | ||||||
|  |      * @param searchKey 模糊查询关键字 | ||||||
|  |      * @param pageNo 当前页 | ||||||
|  |      * @param pageSize 每页多少条 | ||||||
|  |      * @return 当日就诊数据 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public IPage<CurrentDayEncounterDto> getCurrentDayEncounter(String searchKey, Integer pageNo, Integer pageSize) { | ||||||
|  |         // 构建查询条件 | ||||||
|  |         QueryWrapper<CurrentDayEncounterDto> queryWrapper = HisQueryUtils.buildQueryWrapper(null, searchKey, | ||||||
|  |             new HashSet<>(Arrays.asList("patient_name", "organization_name", "practitioner_name", "healthcare_name")), | ||||||
|  |             null); | ||||||
|  |  | ||||||
|  |         IPage<CurrentDayEncounterDto> currentDayEncounter = | ||||||
|  |             outpatientRegistrationAppMapper.getCurrentDayEncounter(new Page<>(pageNo, pageSize), queryWrapper); | ||||||
|  |         currentDayEncounter.getRecords().forEach(e -> { | ||||||
|  |             // 性别 | ||||||
|  |             e.setGenderEnum_enumText(EnumUtils.getInfoByValue(AdministrativeGender.class, e.getGenderEnum())); | ||||||
|  |             // 就诊状态 | ||||||
|  |             e.setStatusEnum_enumText(EnumUtils.getInfoByValue(EncounterStatus.class, e.getStatusEnum())); | ||||||
|  |         }); | ||||||
|  |         return currentDayEncounter; | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -7,6 +7,8 @@ import java.util.List; | |||||||
| import java.util.stream.Collectors; | import java.util.stream.Collectors; | ||||||
| import java.util.stream.Stream; | import java.util.stream.Stream; | ||||||
|  |  | ||||||
|  | import javax.validation.Valid; | ||||||
|  |  | ||||||
| import org.springframework.web.bind.annotation.*; | import org.springframework.web.bind.annotation.*; | ||||||
|  |  | ||||||
| import com.core.common.core.domain.R; | import com.core.common.core.domain.R; | ||||||
| @@ -20,8 +22,6 @@ import com.openhis.web.outpatientservice.dto.OutpatientRegistrationInitDto; | |||||||
| import lombok.AllArgsConstructor; | import lombok.AllArgsConstructor; | ||||||
| import lombok.extern.slf4j.Slf4j; | import lombok.extern.slf4j.Slf4j; | ||||||
|  |  | ||||||
| import javax.validation.Valid; |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * 门诊挂号 controller |  * 门诊挂号 controller | ||||||
|  */ |  */ | ||||||
| @@ -134,4 +134,19 @@ public class OutpatientRegistrationController { | |||||||
|         return iOutpatientRegistrationAppService.saveRegister(outpatientRegistrationAddParam); |         return iOutpatientRegistrationAppService.saveRegister(outpatientRegistrationAddParam); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询当日就诊数据 | ||||||
|  |      *  | ||||||
|  |      * @param searchKey 模糊查询关键字 | ||||||
|  |      * @param pageNo 当前页 | ||||||
|  |      * @param pageSize 每页多少条 | ||||||
|  |      * @return 当日就诊数据 | ||||||
|  |      */ | ||||||
|  |     @GetMapping(value = "/current-day-encounter") | ||||||
|  |     public R<?> getCurrentDayEncounter(@RequestParam(value = "searchKey", defaultValue = "") String searchKey, | ||||||
|  |         @RequestParam(value = "pageNo", defaultValue = "1") Integer pageNo, | ||||||
|  |         @RequestParam(value = "pageSize", defaultValue = "10") Integer pageSize) { | ||||||
|  |         return R.ok(iOutpatientRegistrationAppService.getCurrentDayEncounter(searchKey, pageNo, pageSize)); | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -0,0 +1,92 @@ | |||||||
|  | package com.openhis.web.outpatientservice.dto; | ||||||
|  |  | ||||||
|  | import java.util.Date; | ||||||
|  |  | ||||||
|  | import com.fasterxml.jackson.databind.annotation.JsonSerialize; | ||||||
|  | import com.fasterxml.jackson.databind.ser.std.ToStringSerializer; | ||||||
|  |  | ||||||
|  | import lombok.Data; | ||||||
|  | import lombok.experimental.Accessors; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 当天就诊信息 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | @Accessors(chain = true) | ||||||
|  | public class CurrentDayEncounterDto { | ||||||
|  |  | ||||||
|  |     /** 租户ID */ | ||||||
|  |     private Integer tenantId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 就诊ID | ||||||
|  |      */ | ||||||
|  |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|  |     private Long encounterId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 科室ID | ||||||
|  |      */ | ||||||
|  |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|  |     private Long organizationId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 科室名称 | ||||||
|  |      */ | ||||||
|  |     private String organizationName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 挂号类型 | ||||||
|  |      */ | ||||||
|  |     private String healthcareName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 专家账号id | ||||||
|  |      */ | ||||||
|  |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|  |     private Long practitionerUserId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 专家 | ||||||
|  |      */ | ||||||
|  |     private String practitionerName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 费用性质 | ||||||
|  |      */ | ||||||
|  |     private String contractName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 患者id | ||||||
|  |      */ | ||||||
|  |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|  |     private Long patientId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 患者姓名 | ||||||
|  |      */ | ||||||
|  |     private String patientName; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 患者性别 | ||||||
|  |      */ | ||||||
|  |     private Integer genderEnum; | ||||||
|  |     private String genderEnum_enumText; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 证件号 | ||||||
|  |      */ | ||||||
|  |     private String idCard; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 就诊状态 | ||||||
|  |      */ | ||||||
|  |     private Integer statusEnum; | ||||||
|  |     private String statusEnum_enumText; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 挂号日期/时间 | ||||||
|  |      */ | ||||||
|  |     private Date registerTime; | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -7,6 +7,7 @@ import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | |||||||
| import com.baomidou.mybatisplus.core.metadata.IPage; | import com.baomidou.mybatisplus.core.metadata.IPage; | ||||||
| import com.baomidou.mybatisplus.core.toolkit.Constants; | import com.baomidou.mybatisplus.core.toolkit.Constants; | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
|  | import com.openhis.web.outpatientservice.dto.CurrentDayEncounterDto; | ||||||
| import com.openhis.web.outpatientservice.dto.PractitionerMetadata; | import com.openhis.web.outpatientservice.dto.PractitionerMetadata; | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -27,4 +28,14 @@ public interface OutpatientRegistrationAppMapper { | |||||||
|     Integer getNumByPatientIdAndOrganizationId(@Param("patientId") Long patientId, |     Integer getNumByPatientIdAndOrganizationId(@Param("patientId") Long patientId, | ||||||
|         @Param("serviceTypeId") Long serviceTypeId); |         @Param("serviceTypeId") Long serviceTypeId); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询当日就诊数据 | ||||||
|  |      *  | ||||||
|  |      * @param page 分页参数 | ||||||
|  |      * @param queryWrapper 查询条件 | ||||||
|  |      * @return 当日就诊数据 | ||||||
|  |      */ | ||||||
|  |     IPage<CurrentDayEncounterDto> getCurrentDayEncounter(@Param("page") Page<CurrentDayEncounterDto> page, | ||||||
|  |         @Param(Constants.WRAPPER) QueryWrapper<CurrentDayEncounterDto> queryWrapper); | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -39,4 +39,49 @@ | |||||||
|           AND create_time > CURRENT_DATE |           AND create_time > CURRENT_DATE | ||||||
|     </select> |     </select> | ||||||
|  |  | ||||||
|  |     <select id="getCurrentDayEncounter" resultType="com.openhis.web.outpatientservice.dto.CurrentDayEncounterDto"> | ||||||
|  |         SELECT T9.tenant_id, | ||||||
|  |                T9.encounter_id, | ||||||
|  |                T9.organization_id, | ||||||
|  |                T9.organization_name, | ||||||
|  |                T9.healthcare_name, | ||||||
|  |                T9.practitioner_user_id, | ||||||
|  |                T9.practitioner_name, | ||||||
|  |                T9.contract_name, | ||||||
|  |                T9.patient_id, | ||||||
|  |                T9.patient_name, | ||||||
|  |                T9.gender_enum, | ||||||
|  |                T9.id_card, | ||||||
|  |                T9.status_enum, | ||||||
|  |                T9.register_time | ||||||
|  |         from ( | ||||||
|  |                  SELECT T1.tenant_id       AS tenant_id, | ||||||
|  |                         T1.id              AS encounter_id, | ||||||
|  |                         T1.organization_id AS organization_id, | ||||||
|  |                         T2.NAME            AS organization_name, | ||||||
|  |                         T3.NAME            AS healthcare_name, | ||||||
|  |                         T5.user_id         AS practitioner_user_id, | ||||||
|  |                         T5.NAME            AS practitioner_name, | ||||||
|  |                         T7.contract_name   AS contract_name, | ||||||
|  |                         T8.id              AS patient_id, | ||||||
|  |                         T8.NAME            AS patient_name, | ||||||
|  |                         T8.gender_enum     AS gender_enum, | ||||||
|  |                         T8.id_card         AS id_card, | ||||||
|  |                         T1.status_enum     AS status_enum, | ||||||
|  |                         T1.create_time     AS register_time | ||||||
|  |                  FROM adm_encounter AS T1 | ||||||
|  |                           LEFT JOIN adm_organization AS T2 ON T1.organization_id = T2. | ||||||
|  |                      ID | ||||||
|  |                           LEFT JOIN adm_healthcare_service AS T3 ON T1.service_type_id = T3. | ||||||
|  |                      ID | ||||||
|  |                           LEFT JOIN adm_encounter_participant AS T4 ON T1.ID = T4.encounter_id | ||||||
|  |                           LEFT JOIN adm_practitioner AS T5 ON T5.ID = T4.practitioner_id | ||||||
|  |                           LEFT JOIN adm_account AS T6 ON T1.ID = T6.encounter_id | ||||||
|  |                           LEFT JOIN fin_contract AS T7 ON T6.contract_no = T7.bus_no | ||||||
|  |                           LEFT JOIN adm_patient AS T8 ON T1.patient_id = T8.ID | ||||||
|  |                  WHERE T1.delete_flag = '0' | ||||||
|  |                    AND T1.create_time > CURRENT_DATE) AS T9 | ||||||
|  |             ${ew.customSqlSegment} | ||||||
|  |     </select> | ||||||
|  |  | ||||||
| </mapper> | </mapper> | ||||||
		Reference in New Issue
	
	Block a user
	 Wang.Huan
					Wang.Huan