diff --git a/openhis-server-new/openhis-application/src/main/java/com/openhis/web/inpatient/mapper/InpatientDispensingMapper.java b/openhis-server-new/openhis-application/src/main/java/com/openhis/web/inpatient/mapper/InpatientDispensingMapper.java
index 8e8e3e304..469652667 100644
--- a/openhis-server-new/openhis-application/src/main/java/com/openhis/web/inpatient/mapper/InpatientDispensingMapper.java
+++ b/openhis-server-new/openhis-application/src/main/java/com/openhis/web/inpatient/mapper/InpatientDispensingMapper.java
@@ -3,6 +3,7 @@ package com.openhis.web.inpatient.mapper;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;
+import org.apache.ibatis.annotations.Update;
import java.util.List;
import java.util.Map;
@@ -18,6 +19,9 @@ import java.util.Map;
* 2. 模式 1(需申请):仅查询 apply_status = 'APPLIED' 的记录。
* 3. 模式 2(自动):查询 exec_status = 'EXECUTED' 的记录。
* 4. 确保明细单与汇总单底层查询逻辑一致,消除状态流转不一致风险。
+ *
+ * 修复说明 (Bug #505):
+ * 新增查询发药状态以及退回状态更新的方法,供业务层在退回前进行状态校验。
*/
@Mapper
public interface InpatientDispensingMapper {
@@ -33,7 +37,7 @@ public interface InpatientDispensingMapper {
"SELECT " +
" d.id, d.order_id, d.patient_id, d.patient_name, d.drug_id, d.drug_name, " +
" d.spec, d.dosage, d.quantity, d.exec_status, d.apply_status, d.apply_time, " +
- " d.exec_time, d.ward_id " +
+ " d.exec_time, d.ward_id, d.dispensing_status " + // 新增字段用于退回校验
"FROM his_dispensing_detail d " +
"WHERE d.ward_id = #{wardId} " +
" AND d.is_deleted = 0 " +
@@ -49,16 +53,33 @@ public interface InpatientDispensingMapper {
@Param("submitMode") String submitMode);
/**
- * 更新发药申请状态(用于汇总发药申请提交)
+ * 根据明细 ID 列表查询发药状态(用于退回前校验)。
*
- * @param ids 明细记录ID列表
- * @param operator 操作人
+ * @param detailIds 明细 ID 列表
+ * @return 每条记录的 id 与 dispensing_status
*/
@Select("")
- int updateApplyStatusByIds(@Param("ids") List ids, @Param("operator") String operator);
+ List