package model import ( "gorm.io/gorm" "hospital-admin-api/global" "time" ) // UserDoctorInfo 用户-医生详情表 type UserDoctorInfo struct { DoctorInfoId int64 `gorm:"column:doctor_info_id;type:bigint(19);primary_key;comment:主键" json:"doctor_info_id"` UserId int64 `gorm:"column:user_id;type:bigint(19);comment:用户id" json:"user_id"` DoctorId int64 `gorm:"column:doctor_id;type:bigint(19);comment:医生id" json:"doctor_id"` CardType int `gorm:"column:card_type;type:tinyint(1);comment:类型(1:身份证 2:护照 3:港澳通行证 4:台胞证);NOT NULL" json:"card_type"` CardName string `gorm:"column:card_name;type:varchar(50);comment:证件姓名" json:"card_name"` CardNameMask string `gorm:"column:card_name_mask;type:varchar(50);comment:证件姓名(掩码)" json:"card_name_mask"` CardNum string `gorm:"column:card_num;type:varchar(30);comment:证件号码" json:"card_num"` CardNumMask string `gorm:"column:card_num_mask;type:varchar(50);comment:证件号码(掩码)" json:"card_num_mask"` LicenseCert string `gorm:"column:license_cert;type:varchar(255);comment:医师执业证(逗号分隔)" json:"license_cert"` QualificationCert string `gorm:"column:qualification_cert;type:varchar(255);comment:医师资格证(逗号分隔)" json:"qualification_cert"` QualificationCertNum string `gorm:"column:qualification_cert_num;type:varchar(255);comment:医师资格证号(逗号分隔)" json:"qualification_cert_num"` WorkCert string `gorm:"column:work_cert;type:varchar(255);comment:医师工作证(逗号分隔)" json:"work_cert"` MultiPointImages string `gorm:"column:multi_point_images;type:varchar(255);comment:多点执业备案信息(逗号分隔)" json:"multi_point_images"` IdCardFront string `gorm:"column:id_card_front;type:varchar(255);comment:身份证正面图片" json:"id_card_front"` IdCardBack string `gorm:"column:id_card_back;type:varchar(255);comment:身份证背面图片" json:"id_card_back"` SignImage string `gorm:"column:sign_image;type:varchar(255);comment:签名图片" json:"sign_image"` RegisterCert string `gorm:"column:register_cert;type:varchar(255);comment:电子注册证" json:"register_cert"` Model } func (m *UserDoctorInfo) TableName() string { return "gdxz_user_doctor_info" } func (m *UserDoctorInfo) BeforeCreate(tx *gorm.DB) error { if m.DoctorInfoId == 0 { m.DoctorInfoId = global.Snowflake.Generate().Int64() } m.CreatedAt = LocalTime(time.Now()) tx.Statement.SetColumn("CreatedAt", m.CreatedAt) m.UpdatedAt = LocalTime(time.Now()) tx.Statement.SetColumn("UpdatedAt", m.UpdatedAt) return nil }