列表查询
This commit is contained in:
parent
ed72e480f1
commit
542a8f71ad
@ -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)
|
||||||
|
|||||||
@ -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))
|
||||||
}
|
}
|
||||||
|
|
||||||
// 排序
|
// 排序
|
||||||
|
|||||||
@ -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 取消药品订单
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user