增加了题库不允许重复的业务逻辑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)
|
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 新增问答题库
|
// AddQuestionQa 新增问答题库
|
||||||
func (r *QuestionQa) AddQuestionQa(c *gin.Context) {
|
func (r *QuestionQa) AddQuestionQa(c *gin.Context) {
|
||||||
questionQaRequest := requests.QuestionQaRequest{}
|
questionQaRequest := requests.QuestionQaRequest{}
|
||||||
|
|||||||
@ -211,6 +211,113 @@ func (r *QuestionQaDao) GetQuestionQaPageSearch(req requests.GetQuestionQaPage,
|
|||||||
return m, totalRecords, nil
|
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 自增
|
// Inc 自增
|
||||||
func (r *QuestionQaDao) Inc(tx *gorm.DB, qaId int64, field string, numeral int) error {
|
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
|
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 {
|
type QuestionQaRequest struct {
|
||||||
GetQuestionQaPage // 获取问答题库列表-分页
|
GetQuestionQaPage // 获取问答题库列表-分页
|
||||||
|
GetQuestionQaList // 获取问答题库列表
|
||||||
AddQuestionQa // 新增问答题库
|
AddQuestionQa // 新增问答题库
|
||||||
PutQuestionQa // 修改问答题库
|
PutQuestionQa // 修改问答题库
|
||||||
PutQuestionQaPassword // 修改问答题库密码
|
PutQuestionQaPassword // 修改问答题库密码
|
||||||
@ -25,6 +26,19 @@ type GetQuestionQaPage struct {
|
|||||||
Order *GetQuestionQaPageOrder `json:"order" form:"order" label:"排序"`
|
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 获取题目列表-分页-排序条件
|
// GetQuestionQaPageOrder 获取题目列表-分页-排序条件
|
||||||
type GetQuestionQaPageOrder struct {
|
type GetQuestionQaPageOrder struct {
|
||||||
UpdatedAt string `json:"updated_at" form:"updated_at" label:"排序"`
|
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("/page", api.QuestionQa.GetQuestionQaPage)
|
||||||
|
|
||||||
|
// 获取问答题库列表
|
||||||
|
qaGroup.POST("/list", api.QuestionQa.GetQuestionQaList)
|
||||||
|
|
||||||
// 新增问答题库
|
// 新增问答题库
|
||||||
qaGroup.POST("", api.QuestionQa.AddQuestionQa)
|
qaGroup.POST("", api.QuestionQa.AddQuestionQa)
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user