package dao import ( "gorm.io/gorm" "hospital-admin-api/api/model" "hospital-admin-api/api/requests" "hospital-admin-api/global" ) type HospitalDepartmentCustomDao struct { } // GetHospitalDepartmentCustomById 获取自定义科室数据-自定义科室id func (r *HospitalDepartmentCustomDao) GetHospitalDepartmentCustomById(departmentCustomId int64) (m *model.HospitalDepartmentCustom, err error) { err = global.Db.First(&m, departmentCustomId).Error if err != nil { return nil, err } return m, nil } // AddHospitalDepartmentCustom 新增自定义科室 func (r *HospitalDepartmentCustomDao) AddHospitalDepartmentCustom(tx *gorm.DB, model *model.HospitalDepartmentCustom) (*model.HospitalDepartmentCustom, error) { if err := tx.Create(model).Error; err != nil { return nil, err } return model, nil } // GetHospitalDepartmentCustomList 获取自定义科室列表 func (r *HospitalDepartmentCustomDao) GetHospitalDepartmentCustomList(maps interface{}) (m []*model.HospitalDepartmentCustom, err error) { err = global.Db.Where(maps).Find(&m).Error if err != nil { return nil, err } return m, nil } // DeleteHospitalDepartmentCustomById 删除自定义科室-自定义科室id func (r *HospitalDepartmentCustomDao) DeleteHospitalDepartmentCustomById(tx *gorm.DB, departmentCustomId int64) error { if err := tx.Delete(&model.HospitalDepartmentCustom{}, departmentCustomId).Error; err != nil { return err } return nil } // EditHospitalDepartmentCustomById 修改自定义科室-自定义科室id func (r *HospitalDepartmentCustomDao) EditHospitalDepartmentCustomById(tx *gorm.DB, departmentCustomId int64, data interface{}) error { err := tx.Model(&model.HospitalDepartmentCustom{}).Where("department_custom_id = ?", departmentCustomId).Updates(data).Error if err != nil { return err } return nil } // GetHospitalDepartmentCustomListByMaps 获取自定义科室列表 func (r *HospitalDepartmentCustomDao) GetHospitalDepartmentCustomListByMaps(departmentRequest requests.GetDepartmentCustomList) (m []*model.HospitalDepartmentCustom, err error) { result := global.Db if departmentRequest.DepartmentId != "" { result = result.Where("department_id = ?", departmentRequest.DepartmentId) } if departmentRequest.DepartmentCustomName != "" { result = result.Where("department_custom_name like ?", "%"+departmentRequest.DepartmentCustomName+"%") } if departmentRequest.DepartmentName != "" { result = result.Where("department_name like ?", "%"+departmentRequest.DepartmentName+"%") } if departmentRequest.DepartmentCode != "" { result = result.Where("department_code = ?", departmentRequest.DepartmentCode) } if departmentRequest.DepartmentStatus != 0 { result = result.Where("department_status = ?", departmentRequest.DepartmentStatus) } err = result.Find(&m).Error if err != nil { return nil, err } return m, nil }