增加了题库不允许重复的业务逻辑2
This commit is contained in:
parent
820d8de1d5
commit
f62a48f510
@ -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{}
|
||||
|
||||
@ -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
|
||||
|
||||
@ -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:"排序"`
|
||||
|
||||
@ -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)
|
||||
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user