处理分享

This commit is contained in:
wucongxing8150 2024-09-29 11:42:18 +08:00
parent ba6dbcc2c7
commit c209dafac5
7 changed files with 196 additions and 70 deletions

View File

@ -8,7 +8,6 @@ import (
"knowledge/api/responses" "knowledge/api/responses"
"knowledge/global" "knowledge/global"
"knowledge/utils" "knowledge/utils"
"sort"
"time" "time"
) )
@ -32,7 +31,6 @@ func (r *Share) GetShare(c *gin.Context) {
// 业务处理 // 业务处理
questionQaDao := dao.QuestionQaDao{} questionQaDao := dao.QuestionQaDao{}
questionQaItemDao := dao.QuestionQaItemDao{} questionQaItemDao := dao.QuestionQaItemDao{}
questionDao := dao.QuestionDao{}
// 获取题库数据 // 获取题库数据
maps := make(map[string]interface{}) maps := make(map[string]interface{})
@ -70,27 +68,18 @@ func (r *Share) GetShare(c *gin.Context) {
maps = make(map[string]interface{}) maps = make(map[string]interface{})
maps["qa_id"] = questionQa.QaId maps["qa_id"] = questionQa.QaId
maps["is_must_select"] = 1 maps["is_must_select"] = 1
questionQaItems, err := questionQaItemDao.GetQuestionQaItemList(maps) questionQaItems, err := questionQaItemDao.GetQuestionQaItemrPreloadList(maps)
if err == nil && len(questionQaItems) > 0 { if err == nil && len(questionQaItems) > 0 {
shareQuestionDtos := make([]*dto.ShareQuestionDto, len(questionQaItems))
for i, item := range questionQaItems { for i, item := range questionQaItems {
// 获取题目数据 // 处理返回值
question, err := questionDao.GetQuestionById(item.QuestionId) questionDto := dto.GetShareQuestionDto(item.Question)
if err != nil {
responses.FailWithMessage("题目错误", c)
return
}
shareQuestionDto := dto.GetShareQuestionDto(question) // 加载选项
questionDto.LoadQuestionOption(item.Question.QuestionOption)
shareQuestionDto.IsMustSelect = item.IsMustSelect
// 将转换后的结构体添加到新切片中 // 将转换后的结构体添加到新切片中
shareQuestionDtos[i] = shareQuestionDto g.Question[i] = questionDto
} }
g.Question = shareQuestionDtos
} }
// 题目数据-剩余随机数量 // 题目数据-剩余随机数量
@ -100,30 +89,58 @@ func (r *Share) GetShare(c *gin.Context) {
maps = make(map[string]interface{}) maps = make(map[string]interface{})
maps["qa_id"] = questionQa.QaId maps["qa_id"] = questionQa.QaId
maps["is_must_select"] = 0 maps["is_must_select"] = 0
questionQaItems, err = questionQaItemDao.GetQuestionQaItemListRand(maps, remainingQuantity) questionQaItems, err = questionQaItemDao.GetQuestionQaItemWhereListRand(maps, remainingQuantity)
if err == nil && len(questionQaItems) > 0 { if err == nil && len(questionQaItems) > 0 {
for _, item := range questionQaItems { for _, item := range questionQaItems {
// 获取题目数据 // 处理返回值
question, err := questionDao.GetQuestionById(item.QuestionId) questionDto := dto.GetShareQuestionDto(item.Question)
if err != nil {
responses.FailWithMessage("题目错误", c)
return
}
shareQuestionDto := dto.GetShareQuestionDto(question) // 加载选项
questionDto.LoadQuestionOption(item.Question.QuestionOption)
shareQuestionDto.IsMustSelect = item.IsMustSelect
// 将转换后的结构体添加到新切片中 // 将转换后的结构体添加到新切片中
g.Question = append(g.Question, shareQuestionDto) g.Question = append(g.Question, questionDto)
} }
} }
} }
// 按照难度重新排序题目顺序 // 按照难度重新排序题目顺序
sort.SliceStable(g.Question, func(i, j int) bool { //sort.SliceStable(g.Question, func(i, j int) bool {
return g.Question[i].Difficulty < g.Question[j].Difficulty // return g.Question[i].Difficulty < g.Question[j].Difficulty
}) //})
// 加载飞花令
if questionQa.QaDisplayType == 2 {
questionQaTokenDao := dao.QuestionQaTokenDao{}
maps = make(map[string]interface{})
maps["qa_id"] = questionQa.QaId
questionQaToken, err := questionQaTokenDao.GetQuestionQaTokenList(maps)
if err != nil {
responses.FailWithMessage("内部错误", c)
return
}
baseTokenItemDao := dao.BaseTokenItemDao{}
for _, v := range questionQaToken {
// 加载详细飞花令
baseTokenItem, err := baseTokenItemDao.GetBaseTokenItemPreloadOrderByTokenId(v.TokenId)
if err != nil {
responses.FailWithMessage("内部错误", c)
return
}
// 处理返回值
for _, item := range baseTokenItem {
if len(g.BaseTokenItem) < questionQa.QaQuantity {
// 处理返回值
baseTokenItemDto := dto.GetBaseTokenItemDto(item)
// 将转换后的结构体添加到新切片中
g.BaseTokenItem = append(g.BaseTokenItem, baseTokenItemDto)
}
}
}
}
responses.OkWithData(g, c) responses.OkWithData(g, c)
} }

View File

@ -29,6 +29,18 @@ func (r *BaseTokenItemDao) GetBaseTokenItemPreloadById(ItemId int64) (m *model.B
return m, nil return m, nil
} }
// GetBaseTokenItemPreloadOrderByTokenId 获取数据-加载全部关联-排序-TokenId
func (r *BaseTokenItemDao) GetBaseTokenItemPreloadOrderByTokenId(tokenId int64) (m []*model.BaseTokenItem, err error) {
err = global.Db.Where("token_id = ?", tokenId).
Order("item_sort desc").
Order("created_at desc").
Find(&m).Error
if err != nil {
return nil, err
}
return m, nil
}
// DeleteBaseTokenItem 删除 // DeleteBaseTokenItem 删除
func (r *BaseTokenItemDao) DeleteBaseTokenItem(tx *gorm.DB, maps interface{}) error { func (r *BaseTokenItemDao) DeleteBaseTokenItem(tx *gorm.DB, maps interface{}) error {
err := tx.Where(maps).Delete(&model.BaseTokenItem{}).Error err := tx.Where(maps).Delete(&model.BaseTokenItem{}).Error

View File

@ -3,6 +3,7 @@ package dao
import ( import (
"errors" "errors"
"gorm.io/gorm" "gorm.io/gorm"
"gorm.io/gorm/clause"
"knowledge/api/model" "knowledge/api/model"
"knowledge/api/requests" "knowledge/api/requests"
"knowledge/global" "knowledge/global"
@ -81,6 +82,15 @@ func (r *QuestionQaItemDao) GetQuestionQaItemList(maps interface{}) (m []*model.
return m, nil return m, nil
} }
// GetQuestionQaItemrPreloadList 获取列表-加载全部关联
func (r *QuestionQaItemDao) GetQuestionQaItemrPreloadList(maps interface{}) (m []*model.QuestionQaItem, err error) {
err = global.Db.Preload(clause.Associations).Where(maps).Find(&m).Error
if err != nil {
return nil, err
}
return m, nil
}
// GetQuestionQaItemListRand 获取列表-随机 // GetQuestionQaItemListRand 获取列表-随机
func (r *QuestionQaItemDao) GetQuestionQaItemListRand(maps interface{}, limit int) (m []*model.QuestionQaItem, err error) { func (r *QuestionQaItemDao) GetQuestionQaItemListRand(maps interface{}, limit int) (m []*model.QuestionQaItem, err error) {
err = global.Db.Where(maps).Limit(limit).Order("rand()").Find(&m).Error err = global.Db.Where(maps).Limit(limit).Order("rand()").Find(&m).Error
@ -221,3 +231,39 @@ func (r *QuestionQaItemDao) GetQuestionQaItemPageSearch(req requests.GetQuestion
} }
return m, totalRecords, nil return m, totalRecords, nil
} }
// GetQuestionQaItemWhereListRand 获取列表-随机
func (r *QuestionQaItemDao) GetQuestionQaItemWhereListRand(maps interface{}, limit int) (m []*model.QuestionQaItem, err error) {
query := global.Db.Model(&model.QuestionQaItem{})
query = query.Where(maps)
query = query.Preload("Question")
// 选项
query = query.Preload("Question.QuestionOption")
subQuery := global.Db.Model(&model.Question{}).
Select("question_id").
Where("question_status = ?", 1).
Where("is_delete = ?", 0)
query = query.Where(gorm.Expr("question_id IN (?)", subQuery))
query = query.Limit(limit).Order("rand()")
err = query.Find(&m).Error
if err != nil {
return nil, err
}
return m, nil
}
//subQuery := global.Db.Model(&model.Question{}).
//Where("kb_question.question_id = kb_question_qa_item.question_id").
//Where("question_status = ?", 1).
//Where("is_delete = ?", 0).
//Select("1")
//
//query = query.Where("EXISTS (?)", subQuery)
//
//query = query.Limit(limit).Order("rand()")

View File

@ -72,6 +72,15 @@ func (r *QuestionQaTokenDao) GetQuestionQaTokenList(maps interface{}) (m []*mode
return m, nil return m, nil
} }
// GetQuestionQaTokenPreloadList 获取列表-加载全部关联
func (r *QuestionQaTokenDao) GetQuestionQaTokenPreloadList(maps interface{}) (m []*model.QuestionQaToken, err error) {
err = global.Db.Preload(clause.Associations).Where(maps).Find(&m).Error
if err != nil {
return nil, err
}
return m, nil
}
// GetQuestionQaTokenCount 获取数量 // GetQuestionQaTokenCount 获取数量
func (r *QuestionQaTokenDao) GetQuestionQaTokenCount(maps interface{}) (total int64, err error) { func (r *QuestionQaTokenDao) GetQuestionQaTokenCount(maps interface{}) (total int64, err error) {
err = global.Db.Model(&model.QuestionQaToken{}).Where(maps).Count(&total).Error err = global.Db.Model(&model.QuestionQaToken{}).Where(maps).Count(&total).Error

View File

@ -112,6 +112,32 @@ func GetQuestionListDto(m []*model.Question) []*QuestionDto {
return responses return responses
} }
// GetShareQuestionDto 题目详情-分享
func GetShareQuestionDto(m *model.Question) *QuestionDto {
var questionImage []string
if m.QuestionImage != "" {
result := strings.Split(m.QuestionImage, ",")
if len(result) > 0 {
for _, v := range result {
v = utils.AddOssDomain(v)
questionImage = append(questionImage, v)
}
}
}
return &QuestionDto{
QuestionId: fmt.Sprintf("%d", m.QuestionId),
QuestionName: m.QuestionName,
QuestionType: m.QuestionType,
QuestionSource: m.QuestionSource,
QuestionImage: questionImage,
QuestionAnalysis: m.QuestionAnalysis,
Difficulty: m.Difficulty,
CreatedAt: m.CreatedAt,
UpdatedAt: m.UpdatedAt,
}
}
// LoadFirstLabel 加载一级标签 // LoadFirstLabel 加载一级标签
func (r *QuestionDto) LoadFirstLabel(m *model.Label) *QuestionDto { func (r *QuestionDto) LoadFirstLabel(m *model.Label) *QuestionDto {
if m != nil { if m != nil {

View File

@ -2,50 +2,49 @@ package dto
import ( import (
"knowledge/api/model" "knowledge/api/model"
"knowledge/utils"
"strings"
) )
type ShareDto struct { type ShareDto struct {
QuestionQa *QuestionQaDto `json:"question_qa"` // 题库数据 QuestionQa *QuestionQaDto `json:"question_qa"` // 题库数据
Question []*ShareQuestionDto `json:"question"` // 题目数据 Question []*QuestionDto `json:"question"` // 题库关联题目列表
BaseTokenItem []*BaseTokenItemDto `json:"base_token_item"` // 题库关联飞花令-列表
} }
// ShareQuestionDto 题目数据 //// ShareQuestionDto 题目数据
type ShareQuestionDto struct { //type ShareQuestionDto struct {
QuestionName string `json:"question_name"` // 题目名称 // QuestionName string `json:"question_name"` // 题目名称
QuestionType int `json:"question_type"` // 题目类型(1:单选 2:多选 3:问答 4:判断) // QuestionType int `json:"question_type"` // 题目类型(1:单选 2:多选 3:问答 4:判断)
QuestionSource int `json:"question_source"` // 题目来源1:本题库 2:外部数据) // QuestionSource int `json:"question_source"` // 题目来源1:本题库 2:外部数据)
QuestionImage []string `json:"question_image"` // 题目图片 // QuestionImage []string `json:"question_image"` // 题目图片
QuestionAnswer string `json:"question_answer"` // 答案 // QuestionAnswer string `json:"question_answer"` // 答案
QuestionAnalysis string `json:"question_analysis"` // 解析 // QuestionAnalysis string `json:"question_analysis"` // 解析
Difficulty int `json:"difficulty"` // 难度0:未知 1:低 2:中 3:高) // Difficulty int `json:"difficulty"` // 难度0:未知 1:低 2:中 3:高)
IsMustSelect int `json:"is_must_select"` // 是否必被选中 // IsMustSelect int `json:"is_must_select"` // 是否必被选中
} //}
//
// GetShareQuestionDto 分享题目详情 //// GetShareQuestionDto 分享题目详情
func GetShareQuestionDto(m *model.Question) *ShareQuestionDto { //func GetShareQuestionDto(m *model.Question) *ShareQuestionDto {
var questionImage []string // var questionImage []string
if m.QuestionImage != "" { // if m.QuestionImage != "" {
result := strings.Split(m.QuestionImage, ",") // result := strings.Split(m.QuestionImage, ",")
if len(result) > 0 { // if len(result) > 0 {
for _, v := range result { // for _, v := range result {
v = utils.AddOssDomain(v) // v = utils.AddOssDomain(v)
questionImage = append(questionImage, v) // questionImage = append(questionImage, v)
} // }
} // }
} // }
//
return &ShareQuestionDto{ // return &ShareQuestionDto{
QuestionName: m.QuestionName, // QuestionName: m.QuestionName,
QuestionType: m.QuestionType, // QuestionType: m.QuestionType,
QuestionSource: m.QuestionSource, // QuestionSource: m.QuestionSource,
QuestionImage: questionImage, // QuestionImage: questionImage,
QuestionAnswer: m.QuestionAnswer, // QuestionAnswer: m.QuestionAnswer,
QuestionAnalysis: m.QuestionAnalysis, // QuestionAnalysis: m.QuestionAnalysis,
Difficulty: m.Difficulty, // Difficulty: m.Difficulty,
} // }
} //}
// LoadQuestionQa 加载题库数据 // LoadQuestionQa 加载题库数据
func (r *ShareDto) LoadQuestionQa(m *model.QuestionQa) *ShareDto { func (r *ShareDto) LoadQuestionQa(m *model.QuestionQa) *ShareDto {
@ -54,3 +53,19 @@ func (r *ShareDto) LoadQuestionQa(m *model.QuestionQa) *ShareDto {
} }
return r return r
} }
// LoadQuestion 加载题库关联题目列表
func (r *ShareDto) LoadQuestion(m []*model.Question) *ShareDto {
if len(m) > 0 {
r.Question = GetQuestionListDto(m)
}
return r
}
// LoadBaseTokenItem 加载题库关联飞花令-列表
func (r *ShareDto) LoadBaseTokenItem(m []*model.BaseTokenItem) *ShareDto {
if len(m) > 0 {
r.BaseTokenItem = GetBaseTokenItemListDto(m)
}
return r
}

View File

@ -12,6 +12,7 @@ type QuestionQaToken struct {
TokenId int64 `gorm:"column:token_id;type:bigint(19);comment:飞花令id" json:"token_id"` TokenId int64 `gorm:"column:token_id;type:bigint(19);comment:飞花令id" json:"token_id"`
Sort int `gorm:"column:sort;type:tinyint(1);comment:排序(越大越靠前)" json:"sort"` Sort int `gorm:"column:sort;type:tinyint(1);comment:排序(越大越靠前)" json:"sort"`
Model Model
BaseTokenItem []*BaseTokenItem `gorm:"foreignKey:TokenId;references:token_id" json:"base_token_item"`
} }
func (m *QuestionQaToken) TableName() string { func (m *QuestionQaToken) TableName() string {