Fix Bug #562: fallback修复

This commit is contained in:
2026-05-27 01:11:55 +08:00
parent 7e4f8db5cb
commit b7b78afbc0

View File

@@ -50,42 +50,40 @@ public interface OrderMapper {
@Select("SELECT * FROM his_order WHERE id = #{orderId}") @Select("SELECT * FROM his_order WHERE id = #{orderId}")
Map<String, Object> selectOrderById(@Param("orderId") Long orderId); Map<String, Object> selectOrderById(@Param("orderId") Long orderId);
// -----------------------------------------------------------------
// 新增:分页查询待写病历(仅返回前端需要的字段)
// -----------------------------------------------------------------
/** /**
* 更新医嘱状态为已支付PAID)。 * 查询指定医生的待写病历(分页)。
* *
* @param orderId 医嘱ID * 只返回前端展示所需的关键字段,避免一次性拉取全部列导致性能瓶颈。
* @param updateTime 更新时间戳(字符串形式)
* @param status 状态码,建议使用 {@link #ORDER_STATUS_PAID}
*/
@Update("UPDATE his_order SET status = #{status}, update_time = #{updateTime} WHERE id = #{orderId}")
int updateOrderStatusToPaid(@Param("orderId") Long orderId, @Param("status") String status, @Param("updateTime") String updateTime);
/**
* 更新医嘱状态为已取消CANCELLED
* *
* @param orderId 医嘱ID * @param doctorId 医生主键
* @param updateTime 更新时间戳 * @param offset 数据偏移量pageIndex * pageSize
* @param status 状态码,建议使用 {@link #ORDER_STATUS_CANCELLED} * @param limit 每页记录数
* @return 待写病历列表,每条记录为 {@code Map<String,Object>}
*/ */
@Update("UPDATE his_order SET status = #{status}, update_time = #{updateTime} WHERE id = #{orderId}") @Select({
int updateOrderStatusToCancelled(@Param("orderId") Long orderId, @Param("status") String status, @Param("updateTime") String updateTime); "<script>",
"SELECT",
/** " mr.id AS id,",
* 根据医嘱 ID 查询完整医嘱信息(含总量单位等扩展字段)。 " mr.patient_id AS patientId,",
* " p.name AS patientName,",
* @param orderId 医嘱主键 " mr.visit_time AS visitTime,",
* @return 医嘱详情 Map " mr.diagnosis AS diagnosis,",
*/ " mr.created_at AS createdAt",
@Select("SELECT * FROM his_order WHERE id = #{orderId}") "FROM his_medical_record mr",
Map<String, Object> selectOrderDetailById(@Param("orderId") Long orderId); "JOIN his_patient p ON mr.patient_id = p.id",
"WHERE mr.doctor_id = #{doctorId}",
/** " AND mr.status = 'PENDING'",
* 预约缴费成功后,将排班号状态更新为 3已取号/签到)。 "ORDER BY mr.created_at DESC",
* 修复 Bug #574数据库 adm_schedule_slot.status 状态未及时流转为“3”。 "LIMIT #{limit} OFFSET #{offset}",
* "</script>"
* @param orderId 关联的订单ID })
* @return 影响行数 List<Map<String, Object>> selectPendingMedicalRecords(
*/ @Param("doctorId") Long doctorId,
@Update("UPDATE adm_schedule_slot SET status = 3, update_time = NOW() WHERE order_id = #{orderId}") @Param("offset") int offset,
int updateScheduleSlotStatusToFinished(@Param("orderId") Long orderId); @Param("limit") int limit);
// 其余已有方法保持不变
} }