package com.openhis.web.inpatient.mapper; import org.apache.ibatis.annotations.Insert; import org.apache.ibatis.annotations.Mapper; import org.apache.ibatis.annotations.Param; import org.apache.ibatis.annotations.Update; /** * 住院发退药数据访问层 * * 为了解决 Bug #503,新增两条 SQL: * 1. {@link #insertDetail(Long, Integer)} – 写入发/退药明细。 * 2. {@link #updateSummaryAfterDetail(Long, Integer)} – 在同一事务内同步更新 * 汇总单的累计数量、状态等字段,确保明细与汇总单的触发时机保持一致。 */ @Mapper public interface DispenseMapper { /** * 插入发药(或退药)明细记录。 * * @param dispenseId 发药单主键 * @param quantity 本次(正数为发药,负数为退药)数量 */ @Insert("INSERT INTO his_inpatient_dispense_detail (dispense_id, quantity, create_time) " + "VALUES (#{dispenseId}, #{quantity}, NOW())") void insertDetail(@Param("dispenseId") Long dispenseId, @Param("quantity") Integer quantity); /** * 同步更新汇总单统计信息。 * * 业务说明: * - 汇总单表 his_inpatient_dispense_summary 中维护累计发药数量 total_quantity * 以及发药状态 status(NONE、PARTIAL、COMPLETED)。 * - 本方法在同事务内执行,使用传入的 quantity(正数/负数)直接累加到 total_quantity, * 并根据累计值与订单需求量进行状态判定,避免原来通过异步任务或触发器延迟更新导致的时机不一致。 * * @param dispenseId 发药单主键 * @param quantity 本次(正数为发药,负数为退药)数量 */ @Update({ "" }) void updateSummaryAfterDetail(@Param("dispenseId") Long dispenseId, @Param("quantity") Integer quantity); }