From 7a7b51382bb0c156f53763d5a544f8e941ee5eae Mon Sep 17 00:00:00 2001 From: haomingming Date: Tue, 6 Jan 2026 17:14:02 +0800 Subject: [PATCH] 15 --- api/dao/orderPrescription.go | 26 ++++++++++++++++++-------- 1 file changed, 18 insertions(+), 8 deletions(-) diff --git a/api/dao/orderPrescription.go b/api/dao/orderPrescription.go index 566cbdf..b21be29 100644 --- a/api/dao/orderPrescription.go +++ b/api/dao/orderPrescription.go @@ -444,6 +444,8 @@ func (r *OrderPrescriptionDao) GetOrderTransferPrescriptionExportListSearch(req prescriptionTable := (&model.OrderPrescription{}).TableName() inquiryTable := (&model.OrderInquiry{}).TableName() + userTable := (&model.User{}).TableName() + // 构建查询条件 query := global.Db.Model(&model.OrderPrescription{}) @@ -485,9 +487,13 @@ func (r *OrderPrescriptionDao) GetOrderTransferPrescriptionExportListSearch(req query = query.Where("prescription_code = ?", req.PrescriptionCode) } - // 医生名称 + // // 医生名称 + // if req.DoctorName != "" { + // query = query.Where("doctor_name LIKE ?", "%"+req.DoctorName+"%") + // } + // 医生名称 - 查询抄方医生名称 if req.DoctorName != "" { - query = query.Where("doctor_name LIKE ?", "%"+req.DoctorName+"%") + query = query.Where(userTable+".user_name LIKE ?", "%"+req.DoctorName+"%") } // 患者姓名-就诊人 @@ -495,7 +501,7 @@ func (r *OrderPrescriptionDao) GetOrderTransferPrescriptionExportListSearch(req query = query.Where("patient_name LIKE ?", "%"+req.PatientName+"%") } - // 手机号-医生/患者/就诊人 + // 手机号-医生/患者/就诊人(医生部分改为抄方医生) if req.Mobile != "" { // 就诊人 patientFamilySubQuery := global.Db.Model(&model.PatientFamily{}). @@ -511,16 +517,20 @@ func (r *OrderPrescriptionDao) GetOrderTransferPrescriptionExportListSearch(req Select("patient_id"). Where(gorm.Expr("user_id IN (?)", patientUserSubQuery)) - // 医生 - doctorUserSubQuery := global.Db.Model(&model.User{}). + // 抄方医生:通过手机号找到 user_id -> doctor_id(抄方医生) + transferDoctorUserSubQuery := global.Db.Model(&model.User{}). Select("user_id"). Where("mobile = ?", req.Mobile) - doctorSubQuery := global.Db.Model(&model.UserDoctor{}). + transferDoctorSubQuery := global.Db.Model(&model.UserDoctor{}). Select("doctor_id"). - Where(gorm.Expr("user_id IN (?)", doctorUserSubQuery)) + Where(gorm.Expr("user_id IN (?)", transferDoctorUserSubQuery)) - query = query.Where("patient_id IN (?)", patientSubQuery).Or("doctor_id IN (?)", doctorSubQuery).Or("family_id IN (?)", patientFamilySubQuery) + // 使用 OR 条件:患者匹配 OR 抄方医生匹配 OR 就诊人匹配(整体加括号) + query = query.Where( + gorm.Expr("("+prescriptionTable+".patient_id IN (?) OR "+inquiryTable+".doctor_id IN (?) OR "+prescriptionTable+".family_id IN (?))", + patientSubQuery, transferDoctorSubQuery, patientFamilySubQuery), + ) } // 处方状态