列表查询

This commit is contained in:
haomingming 2026-01-06 14:32:43 +08:00
parent ed72e480f1
commit 542a8f71ad
3 changed files with 63 additions and 19 deletions

View File

@ -187,7 +187,7 @@ func (r *OrderPrescriptionDao) GetOrderPrescriptionPageSearch(req requests.GetOr
// 药品订单编号 // 药品订单编号
if req.OrderProductNo != "" { if req.OrderProductNo != "" {
subQuery := global.Db.Model(&model.OrderInquiry{}). subQuery := global.Db.Model(&model.OrderProduct{}).
Select("order_prescription_id"). Select("order_prescription_id").
Where("order_product_no = ?", req.OrderProductNo) Where("order_product_no = ?", req.OrderProductNo)
query = query.Where("order_prescription_id IN (?)", subQuery) query = query.Where("order_prescription_id IN (?)", subQuery)
@ -259,6 +259,7 @@ func (r *OrderPrescriptionDao) GetOrderPrescriptionTransferPageSearch(req reques
var totalRecords int64 var totalRecords int64
prescriptionTable := (&model.OrderPrescription{}).TableName() prescriptionTable := (&model.OrderPrescription{}).TableName()
inquiryTable := (&model.OrderInquiry{}).TableName() inquiryTable := (&model.OrderInquiry{}).TableName()
doctorTable := (&model.UserDoctor{}).TableName()
// 构建查询条件 // 构建查询条件
query := global.Db.Model(&model.OrderPrescription{}) query := global.Db.Model(&model.OrderPrescription{})
@ -267,6 +268,9 @@ func (r *OrderPrescriptionDao) GetOrderPrescriptionTransferPageSearch(req reques
query = query.Joins("INNER JOIN "+inquiryTable+" ON "+prescriptionTable+".order_inquiry_id = "+inquiryTable+".order_inquiry_id"). query = query.Joins("INNER JOIN "+inquiryTable+" ON "+prescriptionTable+".order_inquiry_id = "+inquiryTable+".order_inquiry_id").
Where(inquiryTable+".transfer_doctor_id IS NOT NULL") Where(inquiryTable+".transfer_doctor_id IS NOT NULL")
// 关联抄方医生表
query = query.Joins("LEFT JOIN " + doctorTable + " ON " + inquiryTable + ".transfer_doctor_id = " + doctorTable + ".doctor_id")
// 患者表 // 患者表
query = query.Preload("UserPatient", func(db *gorm.DB) *gorm.DB { query = query.Preload("UserPatient", func(db *gorm.DB) *gorm.DB {
return db.Omit("open_id", "union_id", "wx_session_key") return db.Omit("open_id", "union_id", "wx_session_key")
@ -302,9 +306,9 @@ func (r *OrderPrescriptionDao) GetOrderPrescriptionTransferPageSearch(req reques
query = query.Where(prescriptionTable+".prescription_code = ?", req.PrescriptionCode) query = query.Where(prescriptionTable+".prescription_code = ?", req.PrescriptionCode)
} }
// 医生名称 // 医生名称 - 查询抄方医生名称
if req.DoctorName != "" { if req.DoctorName != "" {
query = query.Where(prescriptionTable+".doctor_name LIKE ?", "%"+req.DoctorName+"%") query = query.Where(doctorTable+".user_name LIKE ?", "%"+req.DoctorName+"%")
} }
// 患者姓名-就诊人 // 患者姓名-就诊人
@ -312,7 +316,7 @@ func (r *OrderPrescriptionDao) GetOrderPrescriptionTransferPageSearch(req reques
query = query.Where(prescriptionTable+".patient_name LIKE ?", "%"+req.PatientName+"%") query = query.Where(prescriptionTable+".patient_name LIKE ?", "%"+req.PatientName+"%")
} }
// 手机号-医生/患者/就诊人 // 手机号-医生/患者/就诊人(医生部分改为抄方医生)
if req.Mobile != "" { if req.Mobile != "" {
// 就诊人 // 就诊人
patientFamilySubQuery := global.Db.Model(&model.PatientFamily{}). patientFamilySubQuery := global.Db.Model(&model.PatientFamily{}).
@ -328,16 +332,19 @@ func (r *OrderPrescriptionDao) GetOrderPrescriptionTransferPageSearch(req reques
Select("patient_id"). Select("patient_id").
Where(gorm.Expr("user_id IN (?)", patientUserSubQuery)) Where(gorm.Expr("user_id IN (?)", patientUserSubQuery))
// 医生 // 抄方医生:通过手机号找到 user_id -> doctor_id抄方医生
doctorUserSubQuery := global.Db.Model(&model.User{}). transferDoctorUserSubQuery := global.Db.Model(&model.User{}).
Select("user_id"). Select("user_id").
Where("mobile = ?", req.Mobile) Where("mobile = ?", req.Mobile)
doctorSubQuery := global.Db.Model(&model.UserDoctor{}). transferDoctorSubQuery := global.Db.Model(&model.UserDoctor{}).
Select("doctor_id"). Select("doctor_id").
Where(gorm.Expr("user_id IN (?)", doctorUserSubQuery)) Where(gorm.Expr("user_id IN (?)", transferDoctorUserSubQuery))
query = query.Where(prescriptionTable+".patient_id IN (?)", patientSubQuery).Or(prescriptionTable+".doctor_id IN (?)", doctorSubQuery).Or(prescriptionTable+".family_id IN (?)", patientFamilySubQuery) // 使用 OR 条件:患者匹配 OR 抄方医生匹配 OR 就诊人匹配
query = query.Where(prescriptionTable+".patient_id IN (?)", patientSubQuery).
Or(inquiryTable+".transfer_doctor_id IN (?)", transferDoctorSubQuery).
Or(prescriptionTable+".family_id IN (?)", patientFamilySubQuery)
} }
// 处方状态 // 处方状态
@ -360,7 +367,7 @@ func (r *OrderPrescriptionDao) GetOrderPrescriptionTransferPageSearch(req reques
// 药品订单编号 // 药品订单编号
if req.OrderProductNo != "" { if req.OrderProductNo != "" {
subQuery := global.Db.Model(&model.OrderInquiry{}). subQuery := global.Db.Model(&model.OrderProduct{}).
Select("order_prescription_id"). Select("order_prescription_id").
Where("order_product_no = ?", req.OrderProductNo) Where("order_product_no = ?", req.OrderProductNo)
query = query.Where(prescriptionTable+".order_prescription_id IN (?)", subQuery) query = query.Where(prescriptionTable+".order_prescription_id IN (?)", subQuery)
@ -532,7 +539,7 @@ func (r *OrderPrescriptionDao) GetOrderTransferPrescriptionExportListSearch(req
// 药品订单编号 // 药品订单编号
if req.OrderProductNo != "" { if req.OrderProductNo != "" {
subQuery := global.Db.Model(&model.OrderInquiry{}). subQuery := global.Db.Model(&model.OrderProduct{}).
Select("order_prescription_id"). Select("order_prescription_id").
Where("order_product_no = ?", req.OrderProductNo) Where("order_product_no = ?", req.OrderProductNo)
query = query.Where("order_prescription_id IN (?)", subQuery) query = query.Where("order_prescription_id IN (?)", subQuery)
@ -701,7 +708,7 @@ func (r *OrderPrescriptionDao) GetOrderPrescriptionExportListSearch(req requests
// 药品订单编号 // 药品订单编号
if req.OrderProductNo != "" { if req.OrderProductNo != "" {
subQuery := global.Db.Model(&model.OrderInquiry{}). subQuery := global.Db.Model(&model.OrderProduct{}).
Select("order_prescription_id"). Select("order_prescription_id").
Where("order_product_no = ?", req.OrderProductNo) Where("order_product_no = ?", req.OrderProductNo)
query = query.Where("order_prescription_id IN (?)", subQuery) query = query.Where("order_prescription_id IN (?)", subQuery)

View File

@ -130,13 +130,26 @@ func (r *OrderProductDao) GetOrderProductPageSearch(req requests.GetOrderProduct
return db.Omit("open_id", "union_id", "wx_session_key") return db.Omit("open_id", "union_id", "wx_session_key")
}) })
// 医生姓名 // 医生姓名 - 同时查询原医生和抄方医生
if req.DoctorName != "" { if req.DoctorName != "" {
subQuery := global.Db.Model(&model.UserDoctor{}). // 原医生查询条件
originalDoctorSubQuery := global.Db.Model(&model.UserDoctor{}).
Select("doctor_id"). Select("doctor_id").
Where("user_name LIKE ?", "%"+req.DoctorName+"%") Where("user_name LIKE ?", "%"+req.DoctorName+"%")
query = query.Where(gorm.Expr("doctor_id IN (?)", subQuery)) // 抄方医生查询条件
transferDoctorSubQuery := global.Db.Model(&model.UserDoctor{}).
Select("doctor_id").
Where("user_name LIKE ?", "%"+req.DoctorName+"%")
// 查询抄方医生对应的问诊订单ID
inquirySubQuery := global.Db.Model(&model.OrderInquiry{}).
Select("order_inquiry_id").
Where(gorm.Expr("transfer_doctor_id IN (?)", transferDoctorSubQuery))
// 使用 OR 条件:原医生匹配 OR 抄方医生匹配
query = query.Where(gorm.Expr("doctor_id IN (?)", originalDoctorSubQuery)).
Or(gorm.Expr("order_inquiry_id IN (?)", inquirySubQuery))
} }
// 处方 // 处方
@ -190,6 +203,11 @@ func (r *OrderProductDao) GetOrderProductPageSearch(req requests.GetOrderProduct
query = query.Where("order_product_id IN (?)", subQuery) query = query.Where("order_product_id IN (?)", subQuery)
} }
// 处方编号
if req.PrescriptionCode != "" {
query = query.Where("prescription_code = ?", req.PrescriptionCode)
}
// 订单编号 // 订单编号
if req.OrderProductNo != "" { if req.OrderProductNo != "" {
query = query.Where("order_product_no = ?", req.OrderProductNo) query = query.Where("order_product_no = ?", req.OrderProductNo)
@ -320,7 +338,7 @@ func (r *OrderProductDao) GetOrderProductPageSearch(req requests.GetOrderProduct
query = query.Where("consignee_tel LIKE ?", "%"+req.ConsigneeTel+"%") query = query.Where("consignee_tel LIKE ?", "%"+req.ConsigneeTel+"%")
} }
// 手机号-医生/患者 // 手机号-医生/患者 - 同时查询原医生和抄方医生
if req.Mobile != "" { if req.Mobile != "" {
// 患者 // 患者
patientUserSubQuery := global.Db.Model(&model.User{}). patientUserSubQuery := global.Db.Model(&model.User{}).
@ -331,16 +349,33 @@ func (r *OrderProductDao) GetOrderProductPageSearch(req requests.GetOrderProduct
Select("patient_id"). Select("patient_id").
Where(gorm.Expr("user_id IN (?)", patientUserSubQuery)) Where(gorm.Expr("user_id IN (?)", patientUserSubQuery))
// 医生 // 医生
doctorUserSubQuery := global.Db.Model(&model.User{}). doctorUserSubQuery := global.Db.Model(&model.User{}).
Select("user_id"). Select("user_id").
Where("mobile = ?", req.Mobile) Where("mobile = ?", req.Mobile)
doctorSubQuery := global.Db.Model(&model.UserDoctor{}). originalDoctorSubQuery := global.Db.Model(&model.UserDoctor{}).
Select("doctor_id"). Select("doctor_id").
Where(gorm.Expr("user_id IN (?)", doctorUserSubQuery)) Where(gorm.Expr("user_id IN (?)", doctorUserSubQuery))
query = query.Where("patient_id IN (?)", patientSubQuery).Or("doctor_id IN (?)", doctorSubQuery) // 抄方医生
transferDoctorUserSubQuery := global.Db.Model(&model.User{}).
Select("user_id").
Where("mobile = ?", req.Mobile)
transferDoctorSubQuery := global.Db.Model(&model.UserDoctor{}).
Select("doctor_id").
Where(gorm.Expr("user_id IN (?)", transferDoctorUserSubQuery))
// 查询抄方医生对应的问诊订单ID
inquirySubQuery := global.Db.Model(&model.OrderInquiry{}).
Select("order_inquiry_id").
Where(gorm.Expr("transfer_doctor_id IN (?)", transferDoctorSubQuery))
// 使用 OR 条件:患者匹配 OR 原医生匹配 OR 抄方医生匹配
query = query.Where("patient_id IN (?)", patientSubQuery).
Or("doctor_id IN (?)", originalDoctorSubQuery).
Or(gorm.Expr("order_inquiry_id IN (?)", inquirySubQuery))
} }
// 排序 // 排序

View File

@ -33,6 +33,8 @@ type GetOrderProductPage struct {
Mobile string `json:"mobile" form:"mobile" label:"手机号-医生/患者"` Mobile string `json:"mobile" form:"mobile" label:"手机号-医生/患者"`
ProductName string `json:"product_name" form:"product_name" label:"药品名称"` ProductName string `json:"product_name" form:"product_name" label:"药品名称"`
CommonName string `json:"common_name" form:"common_name" label:"药品通用名"` CommonName string `json:"common_name" form:"common_name" label:"药品通用名"`
PrescriptionCode string `json:"prescription_code" form:"prescription_code" label:"处方编号"`
} }
// CancelOrderProduct 取消药品订单 // CancelOrderProduct 取消药品订单