hospital-admin-api/api/dao/orderPrescription.go
haomingming 92781a3624 12
2026-01-06 16:34:24 +08:00

787 lines
24 KiB
Go
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

package dao
import (
"errors"
"hospital-admin-api/api/model"
"hospital-admin-api/api/requests"
"hospital-admin-api/global"
"strings"
"time"
"gorm.io/gorm"
)
type OrderPrescriptionDao struct {
}
// GetById 获取处方-处方id
func (r *OrderPrescriptionDao) GetById(orderPrescriptionId int64) (m *model.OrderPrescription, err error) {
query := global.Db.Model(&model.OrderPrescription{})
// 处方关联问诊表(抄方用)
query = query.Preload("OrderInquiry", func(db *gorm.DB) *gorm.DB {
return db.Preload("UserDoctor", func(db *gorm.DB) *gorm.DB {
return db.Select("user_id", "user_name", "doctor_id")
}).Preload("TransferUserDoctor", func(db *gorm.DB) *gorm.DB {
return db.Select("user_id", "user_name", "doctor_id")
})
})
err = query.First(&m, orderPrescriptionId).Error
if err != nil {
return nil, err
}
return m, nil
}
// Delete 删除处方
func (r *OrderPrescriptionDao) Delete(tx *gorm.DB, maps interface{}) error {
err := tx.Where(maps).Delete(&model.BasicBank{}).Error
if err != nil {
return err
}
return nil
}
// Edit 修改处方
func (r *OrderPrescriptionDao) Edit(tx *gorm.DB, maps interface{}, data interface{}) error {
err := tx.Model(&model.BasicBank{}).Where(maps).Updates(data).Error
if err != nil {
return err
}
return nil
}
// EditById 修改处方-处方id
func (r *OrderPrescriptionDao) EditById(tx *gorm.DB, orderPrescriptionId int64, data interface{}) error {
err := tx.Model(&model.BasicBank{}).Where("order_prescription_id = ?", orderPrescriptionId).Updates(data).Error
if err != nil {
return err
}
return nil
}
// GetList 获取处方列表
func (r *OrderPrescriptionDao) GetList(maps interface{}) (m []*model.OrderPrescription, err error) {
err = global.Db.Where(maps).Find(&m).Error
if err != nil {
return nil, err
}
return m, nil
}
// Add 新增处方
func (r *OrderPrescriptionDao) Add(tx *gorm.DB, model *model.OrderPrescription) (*model.OrderPrescription, error) {
if err := tx.Create(model).Error; err != nil {
return nil, err
}
return model, nil
}
// AddByMap 新增处方-map
func (r *OrderPrescriptionDao) AddByMap(tx *gorm.DB, data map[string]interface{}) (*model.OrderPrescription, error) {
orderPrescription := &model.OrderPrescription{}
if err := tx.Model(&model.OrderPrescription{}).Create(data).Error; err != nil {
return nil, err
}
return orderPrescription, nil
}
// GetOrderPrescriptionPageSearch 获取处方列表-分页
func (r *OrderPrescriptionDao) GetOrderPrescriptionPageSearch(req requests.GetOrderPrescriptionPage, page, pageSize int) (m []*model.OrderPrescription, total int64, err error) {
var totalRecords int64
// 构建查询条件
query := global.Db.Model(&model.OrderPrescription{})
// 患者表
query = query.Preload("UserPatient", func(db *gorm.DB) *gorm.DB {
return db.Omit("open_id", "union_id", "wx_session_key")
})
// 用户表
query = query.Preload("UserPatient.User", func(db *gorm.DB) *gorm.DB {
return db.Omit("user_password", "salt")
})
// 药师表
query = query.Preload("UserPharmacist", func(db *gorm.DB) *gorm.DB {
return db.Omit("open_id", "union_id", "wx_session_key")
})
// 处方关联疾病表
query = query.Preload("OrderPrescriptionIcd")
// 处方关联问诊表(抄方用)
query = query.Preload("OrderInquiry", func(db *gorm.DB) *gorm.DB {
return db.Preload("UserDoctor", func(db *gorm.DB) *gorm.DB {
return db.Select("user_id", "user_name", "doctor_id")
}).Preload("TransferUserDoctor", func(db *gorm.DB) *gorm.DB {
return db.Select("user_id", "user_name", "doctor_id")
})
})
// 患者家庭成员表
query = query.Preload("PatientFamily")
// 处方编号
if req.PrescriptionCode != "" {
query = query.Where("prescription_code = ?", req.PrescriptionCode)
}
// 医生名称
if req.DoctorName != "" {
query = query.Where("doctor_name LIKE ?", "%"+req.DoctorName+"%")
}
// 患者姓名-就诊人
if req.PatientName != "" {
query = query.Where("patient_name LIKE ?", "%"+req.PatientName+"%")
}
// 手机号-医生/患者/就诊人
if req.Mobile != "" {
// 就诊人
patientFamilySubQuery := global.Db.Model(&model.PatientFamily{}).
Select("family_id").
Where("mobile = ?", req.Mobile)
// 患者
patientUserSubQuery := global.Db.Model(&model.User{}).
Select("user_id").
Where("mobile = ?", req.Mobile)
patientSubQuery := global.Db.Model(&model.UserPatient{}).
Select("patient_id").
Where(gorm.Expr("user_id IN (?)", patientUserSubQuery))
// 医生
doctorUserSubQuery := global.Db.Model(&model.User{}).
Select("user_id").
Where("mobile = ?", req.Mobile)
doctorSubQuery := global.Db.Model(&model.UserDoctor{}).
Select("doctor_id").
Where(gorm.Expr("user_id IN (?)", doctorUserSubQuery))
query = query.Where("patient_id IN (?)", patientSubQuery).Or("doctor_id IN (?)", doctorSubQuery).Or("family_id IN (?)", patientFamilySubQuery)
}
// 处方状态
if req.PrescriptionStatus != nil {
query = query.Where("prescription_status = ?", req.PrescriptionStatus)
}
// 药师审核状态
if req.PharmacistAuditStatus != nil {
query = query.Where("pharmacist_audit_status = ?", req.PharmacistAuditStatus)
}
// 问诊订单编号
if req.InquiryNo != "" {
subQuery := global.Db.Model(&model.OrderInquiry{}).
Select("order_inquiry_id").
Where("inquiry_no = ?", req.InquiryNo)
query = query.Where("order_inquiry_id IN (?)", subQuery)
}
// 药品订单编号
if req.OrderProductNo != "" {
subQuery := global.Db.Model(&model.OrderProduct{}).
Select("order_prescription_id").
Where("order_product_no = ?", req.OrderProductNo)
query = query.Where("order_prescription_id IN (?)", subQuery)
}
// 药师审核时间
if req.PharmacistVerifyTime != "" {
pharmacistVerifyTime := strings.Split(req.PharmacistVerifyTime, "&")
if len(pharmacistVerifyTime) == 2 {
startTime, _ := time.Parse("2006-01-02", pharmacistVerifyTime[0])
endTime, _ := time.Parse("2006-01-02", pharmacistVerifyTime[1])
if startTime == endTime {
endTime = endTime.Add(23*time.Hour + 59*time.Minute + 59*time.Second)
}
query = query.Where("pharmacist_verify_time BETWEEN ? AND ?", startTime, endTime)
}
}
// 医生开具处方时间
if req.DoctorCreatedTime != "" {
doctorCreatedTime := strings.Split(req.DoctorCreatedTime, "&")
if len(doctorCreatedTime) == 2 {
startTime, _ := time.Parse("2006-01-02", doctorCreatedTime[0])
endTime, _ := time.Parse("2006-01-02", doctorCreatedTime[1])
if startTime == endTime {
endTime = endTime.Add(23*time.Hour + 59*time.Minute + 59*time.Second)
}
query = query.Where("doctor_created_time BETWEEN ? AND ?", startTime, endTime)
}
}
// 处方过期时间
if req.ExpiredTime != "" {
expiredTime := strings.Split(req.ExpiredTime, "&")
if len(expiredTime) == 2 {
startTime, _ := time.Parse("2006-01-02", expiredTime[0])
endTime, _ := time.Parse("2006-01-02", expiredTime[1])
if startTime == endTime {
endTime = endTime.Add(23*time.Hour + 59*time.Minute + 59*time.Second)
}
query = query.Where("expired_time BETWEEN ? AND ?", startTime, endTime)
}
}
// 排序
query = query.Order("created_at desc")
// 查询总数量
if err := query.Count(&totalRecords).Error; err != nil {
return nil, 0, err
}
err = query.Scopes(model.Paginate(page, pageSize)).Find(&m).Error
if err != nil {
return nil, 0, err
}
return m, totalRecords, nil
}
// GetOrderPrescriptionTransferPageSearch 获取抄方的处方列表-分页
func (r *OrderPrescriptionDao) GetOrderPrescriptionTransferPageSearch(req requests.GetOrderPrescriptionPage, page, pageSize int) (m []*model.OrderPrescription, total int64, err error) {
var totalRecords int64
prescriptionTable := (&model.OrderPrescription{}).TableName()
inquiryTable := (&model.OrderInquiry{}).TableName()
doctorTable := (&model.UserDoctor{}).TableName()
userTable := (&model.User{}).TableName()
// 构建查询条件
query := global.Db.Model(&model.OrderPrescription{})
// 关联问诊表只查询TransferDoctorId不等于null的记录
query = query.Joins("INNER JOIN " + inquiryTable + " ON " + prescriptionTable + ".order_inquiry_id = " + inquiryTable + ".order_inquiry_id").
Where(inquiryTable + ".transfer_doctor_id IS NOT NULL")
// 关联抄方医生表
query = query.Joins("LEFT JOIN " + doctorTable + " ON " + inquiryTable + ".doctor_id = " + doctorTable + ".doctor_id")
// 关联抄方医生对应的用户表(用于按用户姓名查询)
query = query.Joins("LEFT JOIN " + userTable + " ON " + doctorTable + ".user_id = " + userTable + ".user_id")
// 患者表
query = query.Preload("UserPatient", func(db *gorm.DB) *gorm.DB {
return db.Omit("open_id", "union_id", "wx_session_key")
})
// 用户表
query = query.Preload("UserPatient.User", func(db *gorm.DB) *gorm.DB {
return db.Omit("user_password", "salt")
})
// 药师表
query = query.Preload("UserPharmacist", func(db *gorm.DB) *gorm.DB {
return db.Omit("open_id", "union_id", "wx_session_key")
})
// 处方关联疾病表
query = query.Preload("OrderPrescriptionIcd")
// 处方关联问诊表(抄方用)
query = query.Preload("OrderInquiry", func(db *gorm.DB) *gorm.DB {
return db.Preload("UserDoctor", func(db *gorm.DB) *gorm.DB {
return db.Select("user_id", "user_name", "doctor_id")
}).Preload("TransferUserDoctor", func(db *gorm.DB) *gorm.DB {
return db.Select("user_id", "user_name", "doctor_id")
})
})
// 患者家庭成员表
query = query.Preload("PatientFamily")
// 处方编号
if req.PrescriptionCode != "" {
query = query.Where(prescriptionTable+".prescription_code = ?", req.PrescriptionCode)
}
// 医生名称 - 查询抄方医生名称
if req.DoctorName != "" {
query = query.Where(userTable+".user_name LIKE ?", "%"+req.DoctorName+"%")
}
// 患者姓名-就诊人
if req.PatientName != "" {
query = query.Where(prescriptionTable+".patient_name LIKE ?", "%"+req.PatientName+"%")
}
// 手机号-医生/患者/就诊人(医生部分改为抄方医生)
if req.Mobile != "" {
// 就诊人
patientFamilySubQuery := global.Db.Model(&model.PatientFamily{}).
Select("family_id").
Where("mobile = ?", req.Mobile)
// 患者
patientUserSubQuery := global.Db.Model(&model.User{}).
Select("user_id").
Where("mobile = ?", req.Mobile)
patientSubQuery := global.Db.Model(&model.UserPatient{}).
Select("patient_id").
Where(gorm.Expr("user_id IN (?)", patientUserSubQuery))
// 抄方医生:通过手机号找到 user_id -> doctor_id抄方医生
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))
// 使用 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),
)
}
// 处方状态
if req.PrescriptionStatus != nil {
query = query.Where(prescriptionTable+".prescription_status = ?", req.PrescriptionStatus)
}
// 药师审核状态
if req.PharmacistAuditStatus != nil {
query = query.Where(prescriptionTable+".pharmacist_audit_status = ?", req.PharmacistAuditStatus)
}
// 问诊订单编号
if req.InquiryNo != "" {
subQuery := global.Db.Model(&model.OrderInquiry{}).
Select("order_inquiry_id").
Where("inquiry_no = ?", req.InquiryNo)
query = query.Where(prescriptionTable+".order_inquiry_id IN (?)", subQuery)
}
// 药品订单编号
if req.OrderProductNo != "" {
subQuery := global.Db.Model(&model.OrderProduct{}).
Select("order_prescription_id").
Where("order_product_no = ?", req.OrderProductNo)
query = query.Where(prescriptionTable+".order_prescription_id IN (?)", subQuery)
}
// 药师审核时间
if req.PharmacistVerifyTime != "" {
pharmacistVerifyTime := strings.Split(req.PharmacistVerifyTime, "&")
if len(pharmacistVerifyTime) == 2 {
startTime, _ := time.Parse("2006-01-02", pharmacistVerifyTime[0])
endTime, _ := time.Parse("2006-01-02", pharmacistVerifyTime[1])
if startTime == endTime {
endTime = endTime.Add(23*time.Hour + 59*time.Minute + 59*time.Second)
}
query = query.Where(prescriptionTable+".pharmacist_verify_time BETWEEN ? AND ?", startTime, endTime)
}
}
// 医生开具处方时间
if req.DoctorCreatedTime != "" {
doctorCreatedTime := strings.Split(req.DoctorCreatedTime, "&")
if len(doctorCreatedTime) == 2 {
startTime, _ := time.Parse("2006-01-02", doctorCreatedTime[0])
endTime, _ := time.Parse("2006-01-02", doctorCreatedTime[1])
if startTime == endTime {
endTime = endTime.Add(23*time.Hour + 59*time.Minute + 59*time.Second)
}
query = query.Where(prescriptionTable+".doctor_created_time BETWEEN ? AND ?", startTime, endTime)
}
}
// 处方过期时间
if req.ExpiredTime != "" {
expiredTime := strings.Split(req.ExpiredTime, "&")
if len(expiredTime) == 2 {
startTime, _ := time.Parse("2006-01-02", expiredTime[0])
endTime, _ := time.Parse("2006-01-02", expiredTime[1])
if startTime == endTime {
endTime = endTime.Add(23*time.Hour + 59*time.Minute + 59*time.Second)
}
query = query.Where(prescriptionTable+".expired_time BETWEEN ? AND ?", startTime, endTime)
}
}
// 排序
query = query.Order(prescriptionTable + ".created_at desc")
// 查询总数量
if err := query.Count(&totalRecords).Error; err != nil {
return nil, 0, err
}
err = query.Scopes(model.Paginate(page, pageSize)).Find(&m).Error
if err != nil {
return nil, 0, err
}
return m, totalRecords, nil
}
// GetOrderPrescriptionExportListSearch 获取抄方的处方列表-导出
func (r *OrderPrescriptionDao) GetOrderTransferPrescriptionExportListSearch(req requests.OrderPrescriptionExportList) (m []*model.OrderPrescription, err error) {
prescriptionTable := (&model.OrderPrescription{}).TableName()
inquiryTable := (&model.OrderInquiry{}).TableName()
// 构建查询条件
query := global.Db.Model(&model.OrderPrescription{})
// 关联问诊表只查询TransferDoctorId不等于null的记录
query = query.Joins("INNER JOIN " + inquiryTable + " ON " + prescriptionTable + ".order_inquiry_id = " + inquiryTable + ".order_inquiry_id").
Where(inquiryTable + ".transfer_doctor_id IS NOT NULL")
// 患者表
query = query.Preload("UserPatient", func(db *gorm.DB) *gorm.DB {
return db.Omit("open_id", "union_id", "wx_session_key")
})
// 用户表
query = query.Preload("UserPatient.User", func(db *gorm.DB) *gorm.DB {
return db.Omit("user_password", "salt")
})
// 医生表
query = query.Preload("UserDoctor", func(db *gorm.DB) *gorm.DB {
return db.Omit("open_id", "union_id", "wx_session_key")
})
// 药师表
query = query.Preload("UserPharmacist", func(db *gorm.DB) *gorm.DB {
return db.Omit("open_id", "union_id", "wx_session_key")
})
// 处方关联疾病表
query = query.Preload("OrderPrescriptionIcd")
// 患者家庭成员表
query = query.Preload("PatientFamily")
// 当前搜索数据
if req.Type == 1 {
// 处方编号
if req.PrescriptionCode != "" {
query = query.Where("prescription_code = ?", req.PrescriptionCode)
}
// 医生名称
if req.DoctorName != "" {
query = query.Where("doctor_name LIKE ?", "%"+req.DoctorName+"%")
}
// 患者姓名-就诊人
if req.PatientName != "" {
query = query.Where("patient_name LIKE ?", "%"+req.PatientName+"%")
}
// 手机号-医生/患者/就诊人
if req.Mobile != "" {
// 就诊人
patientFamilySubQuery := global.Db.Model(&model.PatientFamily{}).
Select("family_id").
Where("mobile = ?", req.Mobile)
// 患者
patientUserSubQuery := global.Db.Model(&model.User{}).
Select("user_id").
Where("mobile = ?", req.Mobile)
patientSubQuery := global.Db.Model(&model.UserPatient{}).
Select("patient_id").
Where(gorm.Expr("user_id IN (?)", patientUserSubQuery))
// 医生
doctorUserSubQuery := global.Db.Model(&model.User{}).
Select("user_id").
Where("mobile = ?", req.Mobile)
doctorSubQuery := global.Db.Model(&model.UserDoctor{}).
Select("doctor_id").
Where(gorm.Expr("user_id IN (?)", doctorUserSubQuery))
query = query.Where("patient_id IN (?)", patientSubQuery).Or("doctor_id IN (?)", doctorSubQuery).Or("family_id IN (?)", patientFamilySubQuery)
}
// 处方状态
if req.PrescriptionStatus != nil {
query = query.Where("prescription_status = ?", req.PrescriptionStatus)
}
// 药师审核状态
if req.PharmacistAuditStatus != nil {
query = query.Where("pharmacist_audit_status = ?", req.PharmacistAuditStatus)
}
// 问诊订单编号
if req.InquiryNo != "" {
subQuery := global.Db.Model(&model.OrderInquiry{}).
Select("order_inquiry_id").
Where("inquiry_no = ?", req.InquiryNo)
query = query.Where("order_inquiry_id IN (?)", subQuery)
}
// 药品订单编号
if req.OrderProductNo != "" {
subQuery := global.Db.Model(&model.OrderProduct{}).
Select("order_prescription_id").
Where("order_product_no = ?", req.OrderProductNo)
query = query.Where("order_prescription_id IN (?)", subQuery)
}
// 药师审核时间
if req.PharmacistVerifyTime != "" {
pharmacistVerifyTime := strings.Split(req.PharmacistVerifyTime, "&")
if len(pharmacistVerifyTime) == 2 {
startTime, _ := time.Parse("2006-01-02", pharmacistVerifyTime[0])
endTime, _ := time.Parse("2006-01-02", pharmacistVerifyTime[1])
if startTime == endTime {
endTime = endTime.Add(23*time.Hour + 59*time.Minute + 59*time.Second)
}
query = query.Where("pharmacist_verify_time BETWEEN ? AND ?", startTime, endTime)
}
}
// 医生开具处方时间
if req.DoctorCreatedTime != "" {
doctorCreatedTime := strings.Split(req.DoctorCreatedTime, "&")
if len(doctorCreatedTime) == 2 {
startTime, _ := time.Parse("2006-01-02", doctorCreatedTime[0])
endTime, _ := time.Parse("2006-01-02", doctorCreatedTime[1])
if startTime == endTime {
endTime = endTime.Add(23*time.Hour + 59*time.Minute + 59*time.Second)
}
query = query.Where("doctor_created_time BETWEEN ? AND ?", startTime, endTime)
}
}
// 处方过期时间
if req.ExpiredTime != "" {
expiredTime := strings.Split(req.ExpiredTime, "&")
if len(expiredTime) == 2 {
startTime, _ := time.Parse("2006-01-02", expiredTime[0])
endTime, _ := time.Parse("2006-01-02", expiredTime[1])
if startTime == endTime {
endTime = endTime.Add(23*time.Hour + 59*time.Minute + 59*time.Second)
}
query = query.Where("expired_time BETWEEN ? AND ?", startTime, endTime)
}
}
}
// 当前选中数据
if req.Type == 2 {
if req.Id == "" {
return nil, errors.New("未提供需导出数据编号")
}
id := strings.Split(req.Id, ",")
query = query.Where("order_prescription_id IN (?)", id)
}
// 排序
query = query.Order("created_at desc")
err = query.Find(&m).Error
if err != nil {
return nil, err
}
return m, nil
}
// GetOrderPrescriptionExportListSearch 获取处方列表-导出
func (r *OrderPrescriptionDao) GetOrderPrescriptionExportListSearch(req requests.OrderPrescriptionExportList) (m []*model.OrderPrescription, err error) {
// 构建查询条件
query := global.Db.Model(&model.OrderPrescription{})
// 患者表
query = query.Preload("UserPatient", func(db *gorm.DB) *gorm.DB {
return db.Omit("open_id", "union_id", "wx_session_key")
})
// 用户表
query = query.Preload("UserPatient.User", func(db *gorm.DB) *gorm.DB {
return db.Omit("user_password", "salt")
})
// 医生表
query = query.Preload("UserDoctor", func(db *gorm.DB) *gorm.DB {
return db.Omit("open_id", "union_id", "wx_session_key")
})
// 药师表
query = query.Preload("UserPharmacist", func(db *gorm.DB) *gorm.DB {
return db.Omit("open_id", "union_id", "wx_session_key")
})
// 处方关联疾病表
query = query.Preload("OrderPrescriptionIcd")
// 患者家庭成员表
query = query.Preload("PatientFamily")
// 当前搜索数据
if req.Type == 1 {
// 处方编号
if req.PrescriptionCode != "" {
query = query.Where("prescription_code = ?", req.PrescriptionCode)
}
// 医生名称
if req.DoctorName != "" {
query = query.Where("doctor_name LIKE ?", "%"+req.DoctorName+"%")
}
// 患者姓名-就诊人
if req.PatientName != "" {
query = query.Where("patient_name LIKE ?", "%"+req.PatientName+"%")
}
// 手机号-医生/患者/就诊人
if req.Mobile != "" {
// 就诊人
patientFamilySubQuery := global.Db.Model(&model.PatientFamily{}).
Select("family_id").
Where("mobile = ?", req.Mobile)
// 患者
patientUserSubQuery := global.Db.Model(&model.User{}).
Select("user_id").
Where("mobile = ?", req.Mobile)
patientSubQuery := global.Db.Model(&model.UserPatient{}).
Select("patient_id").
Where(gorm.Expr("user_id IN (?)", patientUserSubQuery))
// 医生
doctorUserSubQuery := global.Db.Model(&model.User{}).
Select("user_id").
Where("mobile = ?", req.Mobile)
doctorSubQuery := global.Db.Model(&model.UserDoctor{}).
Select("doctor_id").
Where(gorm.Expr("user_id IN (?)", doctorUserSubQuery))
query = query.Where("patient_id IN (?)", patientSubQuery).Or("doctor_id IN (?)", doctorSubQuery).Or("family_id IN (?)", patientFamilySubQuery)
}
// 处方状态
if req.PrescriptionStatus != nil {
query = query.Where("prescription_status = ?", req.PrescriptionStatus)
}
// 药师审核状态
if req.PharmacistAuditStatus != nil {
query = query.Where("pharmacist_audit_status = ?", req.PharmacistAuditStatus)
}
// 问诊订单编号
if req.InquiryNo != "" {
subQuery := global.Db.Model(&model.OrderInquiry{}).
Select("order_inquiry_id").
Where("inquiry_no = ?", req.InquiryNo)
query = query.Where("order_inquiry_id IN (?)", subQuery)
}
// 药品订单编号
if req.OrderProductNo != "" {
subQuery := global.Db.Model(&model.OrderProduct{}).
Select("order_prescription_id").
Where("order_product_no = ?", req.OrderProductNo)
query = query.Where("order_prescription_id IN (?)", subQuery)
}
// 药师审核时间
if req.PharmacistVerifyTime != "" {
pharmacistVerifyTime := strings.Split(req.PharmacistVerifyTime, "&")
if len(pharmacistVerifyTime) == 2 {
startTime, _ := time.Parse("2006-01-02", pharmacistVerifyTime[0])
endTime, _ := time.Parse("2006-01-02", pharmacistVerifyTime[1])
if startTime == endTime {
endTime = endTime.Add(23*time.Hour + 59*time.Minute + 59*time.Second)
}
query = query.Where("pharmacist_verify_time BETWEEN ? AND ?", startTime, endTime)
}
}
// 医生开具处方时间
if req.DoctorCreatedTime != "" {
doctorCreatedTime := strings.Split(req.DoctorCreatedTime, "&")
if len(doctorCreatedTime) == 2 {
startTime, _ := time.Parse("2006-01-02", doctorCreatedTime[0])
endTime, _ := time.Parse("2006-01-02", doctorCreatedTime[1])
if startTime == endTime {
endTime = endTime.Add(23*time.Hour + 59*time.Minute + 59*time.Second)
}
query = query.Where("doctor_created_time BETWEEN ? AND ?", startTime, endTime)
}
}
// 处方过期时间
if req.ExpiredTime != "" {
expiredTime := strings.Split(req.ExpiredTime, "&")
if len(expiredTime) == 2 {
startTime, _ := time.Parse("2006-01-02", expiredTime[0])
endTime, _ := time.Parse("2006-01-02", expiredTime[1])
if startTime == endTime {
endTime = endTime.Add(23*time.Hour + 59*time.Minute + 59*time.Second)
}
query = query.Where("expired_time BETWEEN ? AND ?", startTime, endTime)
}
}
}
// 当前选中数据
if req.Type == 2 {
if req.Id == "" {
return nil, errors.New("未提供需导出数据编号")
}
id := strings.Split(req.Id, ",")
query = query.Where("order_prescription_id IN (?)", id)
}
// 排序
query = query.Order("created_at desc")
err = query.Find(&m).Error
if err != nil {
return nil, err
}
return m, nil
}