增加了题库不允许重复的业务逻辑2

This commit is contained in:
wucongxing8150 2025-07-29 10:28:33 +08:00
parent 820d8de1d5
commit f62a48f510
4 changed files with 156 additions and 0 deletions

View File

@ -59,6 +59,38 @@ func (r *QuestionQa) GetQuestionQaPage(c *gin.Context) {
responses.OkWithData(result, c)
}
// GetQuestionQaList 获取问答题库列表
func (r *QuestionQa) GetQuestionQaList(c *gin.Context) {
questionQaRequest := requests.QuestionQaRequest{}
req := questionQaRequest.GetQuestionQaList
if err := c.ShouldBind(&req); err != nil {
responses.FailWithMessage(err.Error(), c)
return
}
// 参数验证
if err := global.Validate.Struct(req); err != nil {
responses.FailWithMessage(utils.Translate(err), c)
return
}
questionQaDao := dao.QuestionQaDao{}
questionQa, err := questionQaDao.GetQuestionQaListSearch(req)
if err != nil {
responses.FailWithMessage(err.Error(), c)
return
}
// 处理返回值
g := dto.GetQuestionQaListDto(questionQa)
if err != nil {
responses.FailWithMessage(err.Error(), c)
return
}
responses.OkWithData(g, c)
}
// AddQuestionQa 新增问答题库
func (r *QuestionQa) AddQuestionQa(c *gin.Context) {
questionQaRequest := requests.QuestionQaRequest{}

View File

@ -211,6 +211,113 @@ func (r *QuestionQaDao) GetQuestionQaPageSearch(req requests.GetQuestionQaPage,
return m, totalRecords, nil
}
// GetQuestionQaListSearch 获取列表
func (r *QuestionQaDao) GetQuestionQaListSearch(req requests.GetQuestionQaList) (m []*model.QuestionQa, err error) {
// 构建查询条件
query := global.Db.Model(&model.Label{})
// 名称
if req.QaName != "" {
query = query.Where("qa_name LIKE ?", "%"+req.QaName+"%")
}
// 类型
query = query.Where("qa_type = ?", req.QaType)
// 状态
if req.QaStatus != nil {
query = query.Where("qa_status = ?", req.QaStatus)
}
// 规则解释
if req.QaRuleContent != "" {
query = query.Where("qa_rule_content LIKE ?", "%"+req.QaRuleContent+"%")
}
// 展示类型
if req.QaDisplayType != nil {
query = query.Where("qa_display_type = ?", req.QaDisplayType)
}
// 过期时间
if req.QaExpireTime != "" {
qaExpireTime := strings.Split(req.QaExpireTime, "&")
if len(qaExpireTime) == 2 {
startTime, _ := time.Parse("2006-01-02", qaExpireTime[0])
endTime, _ := time.Parse("2006-01-02", qaExpireTime[1])
endTime = endTime.Add(23*time.Hour + 59*time.Minute + 59*time.Second)
query = query.Where("qa_expire_time BETWEEN ? AND ?", startTime, endTime)
}
}
// 创建时间
if req.CreatedAt != "" {
createdAt := strings.Split(req.CreatedAt, "&")
if len(createdAt) == 2 {
startTime, _ := time.Parse("2006-01-02", createdAt[0])
endTime, _ := time.Parse("2006-01-02", createdAt[1])
endTime = endTime.Add(23*time.Hour + 59*time.Minute + 59*time.Second)
query = query.Where("created_at BETWEEN ? AND ?", startTime, endTime)
}
}
// 修改时间
if req.UpdatedAt != "" {
updatedAt := strings.Split(req.UpdatedAt, "&")
if len(updatedAt) == 2 {
startTime, _ := time.Parse("2006-01-02", updatedAt[0])
endTime, _ := time.Parse("2006-01-02", updatedAt[1])
endTime = endTime.Add(23*time.Hour + 59*time.Minute + 59*time.Second)
query = query.Where("updated_at BETWEEN ? AND ?", startTime, endTime)
}
}
// 排序
if req.Order != nil {
// 有效期
if req.Order.QaExpireTime != "" {
if req.Order.QaExpireTime != "desc" && req.Order.QaExpireTime != "asc" {
return nil, errors.New("排序字段错误")
}
query = query.Order("qa_expire_time " + req.Order.QaExpireTime)
}
// 题目数量
if req.Order.QaQuantity != "" {
if req.Order.QaQuantity != "desc" && req.Order.QaQuantity != "asc" {
return nil, errors.New("排序字段错误")
}
query = query.Order("qa_quantity " + req.Order.QaQuantity)
}
// 修改时间
if req.Order.UpdatedAt != "" {
if req.Order.UpdatedAt != "desc" && req.Order.UpdatedAt != "asc" {
return nil, errors.New("排序字段错误")
}
query = query.Order("updated_at " + req.Order.UpdatedAt)
}
}
// 排序
query = query.Order("created_at desc")
err = query.Find(&m).Error
if err != nil {
return nil, err
}
return m, nil
}
// Inc 自增
func (r *QuestionQaDao) Inc(tx *gorm.DB, qaId int64, field string, numeral int) error {
err := tx.Model(&model.QuestionQa{}).Where("qa_id = ?", qaId).UpdateColumn(field, gorm.Expr(field+" + ?", numeral)).Error

View File

@ -2,6 +2,7 @@ package requests
type QuestionQaRequest struct {
GetQuestionQaPage // 获取问答题库列表-分页
GetQuestionQaList // 获取问答题库列表
AddQuestionQa // 新增问答题库
PutQuestionQa // 修改问答题库
PutQuestionQaPassword // 修改问答题库密码
@ -25,6 +26,19 @@ type GetQuestionQaPage struct {
Order *GetQuestionQaPageOrder `json:"order" form:"order" label:"排序"`
}
// GetQuestionQaList 获取问答题库列表
type GetQuestionQaList struct {
QaName string `json:"qa_name" form:"qa_name" label:"名称"`
QaType int `json:"qa_type" form:"qa_type" label:"题库类型" validate:"required,oneof=1 2 3"` // 1:常规模式 2:固定套题模式 3:多轮固定题型模式)
QaStatus *int `json:"qa_status" form:"qa_status" label:"状态"` // 1:正常 2:过期)
QaRuleContent string `json:"qa_rule_content" form:"qa_rule_content" label:"规则解释"`
QaDisplayType *int `json:"qa_display_type" form:"qa_display_type" label:"展示类型"` // 1:常规 2:飞花令)
QaExpireTime string `json:"qa_expire_time" form:"qa_expire_time" label:"过期时间"` // 注意这里假设LocalTime转换为字符串格式处理
CreatedAt string `json:"created_at" form:"created_at" label:"创建时间"` // 注意这里假设LocalTime转换为字符串格式处理
UpdatedAt string `json:"updated_at" form:"updated_at" label:"修改时间"` // 注意这里假设LocalTime转换为字符串格式处理
Order *GetQuestionQaPageOrder `json:"order" form:"order" label:"排序"`
}
// GetQuestionQaPageOrder 获取题目列表-分页-排序条件
type GetQuestionQaPageOrder struct {
UpdatedAt string `json:"updated_at" form:"updated_at" label:"排序"`

View File

@ -162,6 +162,9 @@ func privateRouter(r *gin.Engine, api controller.Api) {
// 获取问答题库列表-分页
qaGroup.POST("/page", api.QuestionQa.GetQuestionQaPage)
// 获取问答题库列表
qaGroup.POST("/list", api.QuestionQa.GetQuestionQaList)
// 新增问答题库
qaGroup.POST("", api.QuestionQa.AddQuestionQa)