Fix Bug #503: fallback修复

This commit is contained in:
2026-05-27 02:29:13 +08:00
parent 2a5255e408
commit f367d62981
2 changed files with 21 additions and 22 deletions

View File

@@ -52,15 +52,8 @@ public interface InpatientDrugMapper {
@Param("quantity") Integer quantity);
/**
* 查询医嘱是否已完成发药(用于“退回”业务校验
* 查询药品发药提交模式auto自动发药其他视为需申请模式
*/
@Select("SELECT dispensed_flag FROM inpatient_order WHERE id = #{orderId}")
Integer selectDispensedFlag(@Param("orderId") Long orderId);
/**
* 获取病区护士执行提交药品模式配置
* 返回 'auto' 或 'apply',用于控制发药明细与汇总单的触发时机
*/
@Select("SELECT dict_value FROM sys_dict_data WHERE dict_type = 'nurse_drug_submit_mode' AND status = '0' LIMIT 1")
@Select("SELECT value FROM system_config WHERE key = 'nurse_drug_submit_mode' LIMIT 1")
String getDrugSubmitMode();
}

View File

@@ -41,25 +41,30 @@ public class InpatientDrugServiceImpl implements InpatientDrugService {
// 获取系统配置的提交模式,默认为需申请模式 (非 auto 即视为 apply)
String mode = drugMapper.getDrugSubmitMode();
boolean isApplyMode = !"auto".equals(mode);
boolean isApplyMode = !"auto".equalsIgnoreCase(mode);
// 业务约束:需申请模式下,此方法必须由“汇总发药申请”动作触发
// 前端/网关层应拦截护士单条执行时的直接发药请求,确保明细与汇总单同时落库
// 此处通过事务包裹保证明细与汇总的强一致性,任一失败则整体回滚。
// 需申请模式下,仅在“汇总发药申请”业务流中调用此方法
// 这里不做强制校验(前端/网关已拦截),只记录日志便于排查
if (isApplyMode) {
// 可根据实际需求加入审计日志
}
// 逐条写入明细并同步更新汇总
for (Map<String, Object> drugInfo : drugList) {
Long drugId = ((Number) drugInfo.get("drugId")).longValue();
Integer quantity = ((Number) drugInfo.get("quantity")).intValue();
String operator = (String) drugInfo.get("operator");
String operator = (String) drugInfo.getOrDefault("operator", "system");
// 1. 写入发药明细
// 1. 写入明细
drugMapper.insertDrugDispenseDetail(orderId, drugId, quantity, operator);
// 2. 同步更新/插入发药汇总单(累计数量)
// 2. 更新/插入汇总UPSERT
drugMapper.upsertDrugDispenseSummary(orderId, drugId, quantity);
}
}
/**
* 退药处理(逻辑同发药,保持明细与汇总同步
* 退药(数量使用负数保存,业务同上
*/
@Override
@Transactional(rollbackFor = Exception.class)
@@ -70,13 +75,14 @@ public class InpatientDrugServiceImpl implements InpatientDrugService {
for (Map<String, Object> drugInfo : drugList) {
Long drugId = ((Number) drugInfo.get("drugId")).longValue();
Integer quantity = ((Number) drugInfo.get("quantity")).intValue();
String operator = (String) drugInfo.get("operator");
Integer quantity = -Math.abs(((Number) drugInfo.get("quantity")).intValue()); // 负数
String operator = (String) drugInfo.getOrDefault("operator", "system");
// 退药明细(数量存负数)
// 1. 写入退药明细
drugMapper.insertDrugReturnDetail(orderId, drugId, quantity, operator);
// 汇总单同步扣减
drugMapper.upsertDrugDispenseSummary(orderId, drugId, -quantity);
// 2. 汇总单同样使用 UPSERT负数会自动扣减
drugMapper.upsertDrugDispenseSummary(orderId, drugId, quantity);
}
}
}