Compare commits

..

No commits in common. "dd71b69618d6509c2177f25daebee792ab6b37ce" and "a91e9ff3b604e5e710496744bba06217bf043b46" have entirely different histories.

2 changed files with 29 additions and 99 deletions

View File

@ -248,53 +248,3 @@ func (membersDao) EditCommitteeAppointments(req *members.EditCommitteeAppointmen
} }
return return
} }
// 批量查询成员管理,董事会,委员会接口
// 批量查询成员管理
func (membersDao) GetManagementByUuids(uuids []string) (map[string]model.Management, error) {
var managementList []model.Management
err := db.DocDB.Model(&model.Management{}).Where("uuid IN ?", uuids).Find(&managementList).Error
if err != nil {
return nil, err
}
// 转换为map
managementMap := make(map[string]model.Management)
for _, management := range managementList {
managementMap[management.Uuid] = management
}
return managementMap, nil
}
// 批量查询董事会
func (membersDao) GetBoardOfDirectorsByUuids(uuids []string) (map[string]model.BoardOfDirectors, error) {
var boardOfDirectorsList []model.BoardOfDirectors
err := db.DocDB.Model(&model.BoardOfDirectors{}).Where("uuid IN ?", uuids).Find(&boardOfDirectorsList).Error
if err != nil {
return nil, err
}
boardOfDirectorsMap := make(map[string]model.BoardOfDirectors)
for _, boardOfDirectors := range boardOfDirectorsList {
boardOfDirectorsMap[boardOfDirectors.Uuid] = boardOfDirectors
}
return boardOfDirectorsMap, nil
}
// 批量查询委员会
func (membersDao) GetCommitteeAppointmentsByUuids(uuids []string) (map[string]model.CommitteeAppointments, error) {
var committeeAppointmentsList []model.CommitteeAppointments
err := db.DocDB.Model(&model.CommitteeAppointments{}).Where("uuid IN ?", uuids).Find(&committeeAppointmentsList).Error
if err != nil {
return nil, err
}
committeeAppointmentsMap := make(map[string]model.CommitteeAppointments)
for _, committeeAppointments := range committeeAppointmentsList {
committeeAppointmentsMap[committeeAppointments.Uuid] = committeeAppointments
}
return committeeAppointmentsMap, nil
}

View File

@ -72,63 +72,43 @@ func (membersLogic) GetMemberList(req *members.GetMemberListReq) (result *member
Operator: member.Operator, Operator: member.Operator,
} }
} }
for _, v := range result.Data {
if len(result.Data) > 0 { management, err := dao.MembersDao.GetManagementByUuid(v.Uuid)
// 收集所有UUID
uuids := make([]string, len(result.Data))
for i, member := range result.Data {
uuids[i] = member.Uuid
}
// 批量查询所有关联数据
managementMap, err := dao.MembersDao.GetManagementByUuids(uuids)
if err != nil { if err != nil {
return nil, errors.New("批量查询成员管理失败") return nil, errors.New("查询成员管理失败")
}
v.Management = &members.Management{
Name: management.Name,
Image: management.Image,
Brief: management.Brief,
Introduction: management.Introduction,
Status: management.Status,
IsSetting: management.IsSetting,
} }
boardOfDirectorsMap, err := dao.MembersDao.GetBoardOfDirectorsByUuids(uuids) boardOfDirectors, err := dao.MembersDao.GetBoardOfDirectorsByUuid(v.Uuid)
if err != nil { if err != nil {
return nil, errors.New("批量查询董事会失败") return nil, errors.New("查询董事会失败")
}
v.BoardOfDirectors = &members.BoardOfDirectors{
Name: boardOfDirectors.Name,
Status: boardOfDirectors.Status,
Brief: boardOfDirectors.Brief,
Introduction: boardOfDirectors.Introduction,
IsSetting: boardOfDirectors.IsSetting,
} }
committeeAppointmentsMap, err := dao.MembersDao.GetCommitteeAppointmentsByUuids(uuids) committeeAppointments, err := dao.MembersDao.GetCommitteeAppointmentsByUuid(v.Uuid)
if err != nil { if err != nil {
return nil, errors.New("批量查询委员会失败") return nil, errors.New("查询委员会失败")
} }
v.CommitteeAppointments = &members.CommitteeAppointments{
// 批量赋值 Name: committeeAppointments.Name,
for _, member := range result.Data { Status: committeeAppointments.Status,
if management, exists := managementMap[member.Uuid]; exists { AuditCommittee: committeeAppointments.AuditCommittee,
member.Management = &members.Management{ CompensationCommittee: committeeAppointments.CompensationCommittee,
Name: management.Name, NominatingCommittee: committeeAppointments.NominatingCommittee,
Image: management.Image, IsSetting: committeeAppointments.IsSetting,
Brief: management.Brief,
Introduction: management.Introduction,
Status: management.Status,
IsSetting: management.IsSetting,
}
}
if boardOfDirectors, exists := boardOfDirectorsMap[member.Uuid]; exists {
member.BoardOfDirectors = &members.BoardOfDirectors{
Name: boardOfDirectors.Name,
Status: boardOfDirectors.Status,
Brief: boardOfDirectors.Brief,
Introduction: boardOfDirectors.Introduction,
IsSetting: boardOfDirectors.IsSetting,
}
}
if committeeAppointments, exists := committeeAppointmentsMap[member.Uuid]; exists {
member.CommitteeAppointments = &members.CommitteeAppointments{
Name: committeeAppointments.Name,
Status: committeeAppointments.Status,
AuditCommittee: committeeAppointments.AuditCommittee,
CompensationCommittee: committeeAppointments.CompensationCommittee,
NominatingCommittee: committeeAppointments.NominatingCommittee,
IsSetting: committeeAppointments.IsSetting,
}
}
} }
} }
return result, nil return result, nil