85 lines
2.8 KiB
Go
85 lines
2.8 KiB
Go
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
|
|
}
|