This commit is contained in:
zhouwentao 2026-02-01 13:48:36 +08:00
parent c195147a6e
commit 0d390100b4
5 changed files with 117 additions and 40 deletions

View File

@ -14,6 +14,7 @@ import (
"server/modules/yx/entity"
"server/modules/yx/mapper"
"server/modules/yx/service"
"server/types"
"strings"
"time"
@ -207,7 +208,7 @@ func (s *UserScoreService) GetVolunteerDetail(userID string) (*vo.VolunteerDetai
EnrollProbability: r.EnrollProbability,
StudentConvertedScore: r.StudentConvertedScore,
CreateBy: r.CreateBy,
CreateTime: r.CreateTime,
CreateTime: types.NewDateTime(r.CreateTime),
CalculationMajorID: r.CalculationMajorID,
}
key := r.SchoolCode + "_" + r.MajorCode + "_" + r.EnrollmentCode
@ -249,9 +250,9 @@ func (s *UserScoreService) GetVolunteerDetail(userID string) (*vo.VolunteerDetai
CreateType: volunteer.CreateType,
State: volunteer.State,
CreateBy: volunteer.CreateBy,
CreateTime: volunteer.CreateTime,
CreateTime: types.NewDateTime(volunteer.CreateTime),
UpdateBy: volunteer.UpdateBy,
UpdateTime: volunteer.UpdateTime,
UpdateTime: types.NewDateTime(volunteer.UpdateTime),
}
itemMap := make(map[string][]vo.VolunteerDetailVO)

View File

@ -1,21 +1,21 @@
package vo
import "time"
import "server/types"
// VolunteerDetailVO 志愿详情视图对象
type VolunteerDetailVO struct {
ID string `json:"id"` // 志愿记录ID
VolunteerID string `json:"volunteerId"` // 志愿单ID
SchoolCode string `json:"schoolCode"` // 院校代码
MajorCode string `json:"majorCode"` // 专业代码
EnrollmentCode string `json:"enrollmentCode"` // 招生代码
Indexs int `json:"indexs"` // 志愿序号
Batch string `json:"batch"` // 批次
EnrollProbability float64 `json:"enrollProbability"` // 录取概率
StudentConvertedScore float64 `json:"studentConvertedScore"` // 学生折合分
CreateBy string `json:"createBy"` // 创建人
CreateTime time.Time `json:"createTime"` // 创建时间
CalculationMajorID string `json:"calculationMajorId"` // 计算专业ID
ID string `json:"id"` // 志愿记录ID
VolunteerID string `json:"volunteerId"` // 志愿单ID
SchoolCode string `json:"schoolCode"` // 院校代码
MajorCode string `json:"majorCode"` // 专业代码
EnrollmentCode string `json:"enrollmentCode"` // 招生代码
Indexs int `json:"indexs"` // 志愿序号
Batch string `json:"batch"` // 批次
EnrollProbability float64 `json:"enrollProbability"` // 录取概率
StudentConvertedScore float64 `json:"studentConvertedScore"` // 学生折合分
CreateBy string `json:"createBy"` // 创建人
CreateTime types.DateTime `json:"createTime"` // 创建时间
CalculationMajorID string `json:"calculationMajorId"` // 计算专业ID
// 扩展字段(来自 SchoolMajorDTO
SchoolName string `json:"schoolName"` // 院校名称
MajorName string `json:"majorName"` // 专业名称
@ -36,15 +36,15 @@ type VolunteerDetailResponse struct {
// VolunteerInfoVO 志愿单信息视图对象
type VolunteerInfoVO struct {
ID string `json:"id"`
VolunteerName string `json:"volunteerName"`
ScoreId string `json:"scoreId"`
CreateType string `json:"createType"`
State string `json:"state"`
CreateBy string `json:"createBy"`
CreateTime time.Time `json:"createTime"`
UpdateBy string `json:"updateBy"`
UpdateTime time.Time `json:"updateTime"`
ID string `json:"id"`
VolunteerName string `json:"volunteerName"`
ScoreId string `json:"scoreId"`
CreateType string `json:"createType"`
State string `json:"state"`
CreateBy string `json:"createBy"`
CreateTime types.DateTime `json:"createTime"`
UpdateBy string `json:"updateBy"`
UpdateTime types.DateTime `json:"updateTime"`
}
// VolunteerItemsVO 志愿明细列表视图对象

View File

@ -74,14 +74,14 @@ type SchoolMajorDTO struct {
HistoryMajorEnrollMap map[string]YxHistoryMajorEnrollDTO `json:"historyMajorEnrollMap"`
// 计算相关字段 (非数据库直接映射)
HistoryMajorEnrollList []vo.YxHistoryMajorEnrollVO `json:"historyMajorEnrollList"`
EnrollProbability float64 `json:"enrollProbability"` // 录取率
StudentScore float64 `json:"studentScore"` // 学生折合分
PrivateStudentScore float64 `json:"privateStudentScore"` // 学生折合分(私有)
StudentConvertedScore float64 `json:"studentConvertedScore"` // 学生折合分(转换后)
FirstLevelDiscipline string `json:"firstLevelDiscipline"` // 一级学科 (需确认来源)
Province string `json:"province"` // 省份
SchoolNature string `json:"schoolNature" gorm:"column:schoolNature"` // 院校性质
InstitutionType string `json:"institutionType" gorm:"column:institutionType"` // 院校类型
EnrollProbability float64 `json:"enrollProbability"` // 录取率
StudentScore float64 `json:"studentScore"` // 学生折合分
PrivateStudentScore float64 `json:"privateStudentScore"` // 学生折合分(私有)
StudentConvertedScore float64 `json:"studentConvertedScore"` // 学生折合分(转换后)
FirstLevelDiscipline string `json:"firstLevelDiscipline"` // 一级学科 (需确认来源)
Province string `json:"province"` // 省份
SchoolNature string `json:"schoolNature" gorm:"column:schoolNature"` // 院校性质
InstitutionType string `json:"institutionType" gorm:"column:institutionType"` // 院校类型
}
type YxHistoryMajorEnrollDTO struct {

View File

@ -1,14 +1,19 @@
package vo
import (
"server/modules/yx/entity"
"server/types"
)
// UserVolunteerVO 志愿单视图对象,关联成绩信息
type UserVolunteerVO struct {
entity.YxVolunteer
ProfessionalCategory string `json:"professionalCategory"` // 专业类别
Province string `json:"province"` // 省份
CulturalScore float64 `json:"culturalScore"` // 文化分
ProfessionalScore float64 `json:"professionalScore"` // 专业成绩分
ID string `gorm:"column:id;primaryKey" json:"id"`
VolunteerName string `gorm:"column:volunteer_name" json:"volunteerName"` // 志愿单名称
ScoreId string `gorm:"column:score_id" json:"scoreId"` // 使用成绩id
CreateType string `gorm:"column:create_type;default:1" json:"createType"` // 生成类型(1.手动生成,2.智能生成)
State string `gorm:"column:state;default:0" json:"state"` // 志愿单状态(0-否1.正在使用2-历史)
UpdateTime types.DateTime `gorm:"column:update_time" json:"updateTime"` // 更新日期
ProfessionalCategory string `json:"professionalCategory"` // 专业类别
Province string `json:"province"` // 省份
CulturalScore float64 `json:"culturalScore"` // 文化分
ProfessionalScore float64 `json:"professionalScore"` // 专业成绩分
}

71
server/types/date_time.go Normal file
View File

@ -0,0 +1,71 @@
package types
import (
"database/sql/driver"
"encoding/json"
"time"
)
// DateTime 自定义时间类型JSON序列化格式为 '2006-01-02 15:04:05'
type DateTime time.Time
// MarshalJSON 实现 json.Marshaler 接口,将时间序列化为 '2006-01-02 15:04:05' 格式
func (dt DateTime) MarshalJSON() ([]byte, error) {
t := time.Time(dt)
if t.IsZero() {
return []byte("null"), nil
}
formatted := t.Format("2006-01-02 15:04:05")
return json.Marshal(formatted)
}
// UnmarshalJSON 实现 json.Unmarshaler 接口,解析 '2006-01-02 15:04:05' 格式的时间
func (dt *DateTime) UnmarshalJSON(data []byte) error {
if string(data) == "null" {
return nil
}
var str string
if err := json.Unmarshal(data, &str); err != nil {
return err
}
t, err := time.Parse("2006-01-02 15:04:05", str)
if err != nil {
return err
}
*dt = DateTime(t)
return nil
}
// Value 实现 driver.Valuer 接口,用于数据库存储
func (dt DateTime) Value() (driver.Value, error) {
t := time.Time(dt)
return t, nil
}
// Scan 实现 sql.Scanner 接口,用于数据库读取
func (dt *DateTime) Scan(value interface{}) error {
if value == nil {
return nil
}
t, ok := value.(time.Time)
if !ok {
return nil
}
*dt = DateTime(t)
return nil
}
// Time 转换为标准 time.Time 类型
func (dt DateTime) Time() time.Time {
return time.Time(dt)
}
// NewDateTime 从 time.Time 创建 DateTime
func NewDateTime(t time.Time) DateTime {
return DateTime(t)
}
// Now 创建当前时间的 DateTime
func Now() DateTime {
return DateTime(time.Now())
}