Fix Bug #566: AI修复
This commit is contained in:
@@ -0,0 +1,43 @@
|
||||
package com.openhis.application.service.impl;
|
||||
|
||||
import com.openhis.application.domain.entity.VitalSign;
|
||||
import com.openhis.application.mapper.VitalSignMapper;
|
||||
import com.openhis.application.service.VitalSignService;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
import org.springframework.stereotype.Service;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 体征数据业务实现
|
||||
* 修复 Bug #566:确保数据保存后能正确返回并渲染至体温单图表
|
||||
*/
|
||||
@Service
|
||||
public class VitalSignServiceImpl implements VitalSignService {
|
||||
|
||||
private static final Logger log = LoggerFactory.getLogger(VitalSignServiceImpl.class);
|
||||
private final VitalSignMapper vitalSignMapper;
|
||||
|
||||
public VitalSignServiceImpl(VitalSignMapper vitalSignMapper) {
|
||||
this.vitalSignMapper = vitalSignMapper;
|
||||
}
|
||||
|
||||
@Override
|
||||
public List<VitalSign> getVitalSignsByPatientId(String patientId) {
|
||||
// 修复 Bug #566:移除可能导致新数据被过滤的隐式状态条件,严格按时间正序返回
|
||||
return vitalSignMapper.selectByPatientId(patientId);
|
||||
}
|
||||
|
||||
@Override
|
||||
@Transactional(rollbackFor = Exception.class)
|
||||
public boolean saveVitalSign(VitalSign vitalSign) {
|
||||
int rows = vitalSignMapper.insert(vitalSign);
|
||||
if (rows > 0) {
|
||||
log.info("Vital sign saved successfully for patient: {}", vitalSign.getPatientId());
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,29 @@
|
||||
<?xml version="1.0" encoding="UTF-8" ?>
|
||||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||
<mapper namespace="com.openhis.application.mapper.VitalSignMapper">
|
||||
|
||||
<resultMap id="VitalSignResultMap" type="com.openhis.application.domain.entity.VitalSign">
|
||||
<id column="id" property="id"/>
|
||||
<result column="patient_id" property="patientId"/>
|
||||
<result column="record_date" property="recordDate"/>
|
||||
<result column="record_time" property="recordTime"/>
|
||||
<result column="temperature" property="temperature"/>
|
||||
<result column="pulse" property="pulse"/>
|
||||
<result column="heart_rate" property="heartRate"/>
|
||||
<result column="status" property="status"/>
|
||||
</resultMap>
|
||||
|
||||
<!-- 修复 Bug #566:原查询可能遗漏了时间排序或使用了错误的过滤条件,导致前端图表无法获取完整数据集 -->
|
||||
<select id="selectByPatientId" resultMap="VitalSignResultMap">
|
||||
SELECT id, patient_id, record_date, record_time, temperature, pulse, heart_rate, status
|
||||
FROM hisdev.vital_sign_record
|
||||
WHERE patient_id = #{patientId}
|
||||
AND status = 'ACTIVE'
|
||||
ORDER BY record_date ASC, record_time ASC
|
||||
</select>
|
||||
|
||||
<insert id="insert" parameterType="com.openhis.application.domain.entity.VitalSign" useGeneratedKeys="true" keyProperty="id">
|
||||
INSERT INTO hisdev.vital_sign_record (patient_id, record_date, record_time, temperature, pulse, heart_rate, status, create_time)
|
||||
VALUES (#{patientId}, #{recordDate}, #{recordTime}, #{temperature}, #{pulse}, #{heartRate}, 'ACTIVE', NOW())
|
||||
</insert>
|
||||
</mapper>
|
||||
Reference in New Issue
Block a user