Fix Bug #561: fallback修复

This commit is contained in:
2026-05-27 03:16:42 +08:00
parent 993e65428f
commit 954fefbf0e

View File

@@ -2,12 +2,14 @@ package com.openhis.application.service.impl;
import com.openhis.application.domain.entity.OrderDetail;
import com.openhis.application.domain.entity.OrderMain;
import com.openhis.application.domain.entity.CatalogItem;
import com.openhis.application.mapper.OrderDetailMapper;
import com.openhis.application.mapper.OrderMainMapper;
import com.openhis.application.mapper.CatalogItemMapper;
import com.openhis.application.domain.entity.CatalogItem;
import com.openhis.application.exception.BusinessException;
import com.openhis.application.service.OrderService;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
@@ -18,21 +20,15 @@ import java.util.List;
*
* 修复 Bug #561医嘱录入后总量单位显示异常显示为 “null” 而非诊疗目录配置值。
*
* 根因分析:
* 1. 在医嘱保存saveOrUpdate仅持久化了 OrderDetail 中的药品/检查代码等信息,
* 并未从诊疗目录catalog_item中读取对应的计量单位unit并回写到 OrderDetail。
* 2. 前端展示总量单位时直接读取 OrderDetail.unit导致该字段为 null页面显示 “null”。
*
* 解决方案:
* - 在保存医嘱明细前,根据明细的 itemCode或 itemId查询诊疗目录对应的 CatalogItem
* 将其配置的 unit计量单位填充到 OrderDetail.unit。
* - 为兼容已有数据,若查询不到对应的 CatalogItem则保持原有值防止 NPE并记录日志供后续数据清洗使用。
*
* 该实现保证了医嘱录入后前端能够正确展示配置的计量单位,消除 “null” 显示问题。
* 在保存医嘱明细前,根据明细的 itemCode或 itemId查询诊疗目录对应的 CatalogItem
* 将其配置的 unit计量单位填充到 OrderDetail.unit。
*/
@Service
public class OrderServiceImpl implements OrderService {
private static final Logger log = LoggerFactory.getLogger(OrderServiceImpl.class);
private final OrderMainMapper orderMainMapper;
private final OrderDetailMapper orderDetailMapper;
private final CatalogItemMapper catalogItemMapper;
@@ -48,53 +44,49 @@ public class OrderServiceImpl implements OrderService {
@Override
@Transactional(rollbackFor = Exception.class)
public void saveOrUpdate(OrderMain orderMain, List<OrderDetail> details) {
// 保存更新主表
// 1. 保存/更新医嘱主表
if (orderMain.getId() == null) {
orderMainMapper.insert(orderMain);
} else {
orderMainMapper.updateById(orderMain);
}
// 先删除旧的明细(若是更新场景),再重新插入
// 2. 处理医嘱明细
// a) 先删除旧的明细(如果是更新场景)
if (orderMain.getId() != null) {
orderDetailMapper.deleteByOrderId(orderMain.getId());
}
// 为每条明细补全计量单位
// b) 为每条明细补全计量单位
for (OrderDetail detail : details) {
// 通过目录项编码或ID获取对应的计量单位
CatalogItem catalogItem = null;
if (detail.getItemCode() != null) {
catalogItem = catalogItemMapper.selectByItemCode(detail.getItemCode());
} else if (detail.getItemId() != null) {
catalogItem = catalogItemMapper.selectById(detail.getItemId());
// 若前端已经传入 unit保持不变否则尝试从诊疗目录获取
if (detail.getUnit() == null || detail.getUnit().trim().isEmpty()) {
CatalogItem catalog = null;
try {
if (detail.getItemCode() != null && !detail.getItemCode().trim().isEmpty()) {
catalog = catalogItemMapper.selectByItemCode(detail.getItemCode());
} else if (detail.getItemId() != null) {
catalog = catalogItemMapper.selectById(detail.getItemId());
}
} catch (Exception e) {
log.warn("Failed to query CatalogItem for detail (orderId={}, itemCode={}, itemId={})",
orderMain.getId(), detail.getItemCode(), detail.getItemId(), e);
}
if (catalog != null && catalog.getUnit() != null) {
detail.setUnit(catalog.getUnit());
} else {
// 兼容旧数据,保持为空但记录日志,避免 NPE
log.info("Catalog unit not found for OrderDetail (orderId={}, itemCode={}, itemId={})",
orderMain.getId(), detail.getItemCode(), detail.getItemId());
}
}
if (catalogItem != null) {
// 将目录配置的单位写入明细
detail.setUnit(catalogItem.getUnit());
} else {
// 若未找到对应目录,保持原值并记录警告(避免 NPE
// 这里使用标准日志框架记录,实际项目中请注入 Logger
System.err.println("[WARN] OrderDetail (itemCode=" + detail.getItemCode()
+ ", itemId=" + detail.getItemId() + ") 未匹配到诊疗目录unit 仍为 null");
}
// 关联主表ID并插入
// 设置外键关联
detail.setOrderId(orderMain.getId());
// 插入明细
orderDetailMapper.insert(detail);
}
}
@Override
public OrderMain getById(Long id) {
OrderMain order = orderMainMapper.selectById(id);
if (order != null) {
List<OrderDetail> details = orderDetailMapper.selectByOrderId(id);
order.setDetails(details);
}
return order;
}
// 其它业务方法保持不变...
}