package dao import ( "context" "encoding/json" "fmt" "time" xsql "database/sql" "go-common/app/admin/main/videoup-task/model" "go-common/library/database/sql" "go-common/library/log" "go-common/library/xstr" ) const ( _inQAVideo = "INSERT INTO task_qa_video(cid,aid,task_id,task_utime,attribute,mid,fans,up_groups,arc_title,arc_typeid,audit_status,audit_tagid,audit_submit,audit_details,ctime,mtime) values(?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)" _QATaskVideo = `SELECT qa.id, qa.state, qa.type, qa.detail_id, qa.uid, qa.ftime, qa.ctime, qav.cid, qav.aid, coalesce(qav.task_id, 0) task_id, qav.task_utime, qav.attribute, qav.audit_tagid, qav.arc_title, qav.arc_typeid, qav.audit_status, qav.audit_submit, qav.audit_details, qav.mid, qav.fans, qav.up_groups FROM task_qa qa LEFT JOIN task_qa_video qav ON qa.detail_id = qav.id WHERE qa.id = ? LIMIT 1` _QATaskVideoSimple = `SELECT qa.id, qa.state, qa.type, qa.detail_id, qa.uid, qa.ftime, qa.ctime, qav.cid, qav.aid, coalesce(qav.task_id, 0) task_id,qav.task_utime, qav.attribute, qav.audit_tagid, qav.arc_title, qav.arc_typeid, qav.audit_status, qav.audit_submit, qav.mid, qav.fans, qav.up_groups FROM task_qa qa LEFT JOIN task_qa_video qav ON qa.detail_id = qav.id WHERE qa.id = ? LIMIT 1` _QAVideoDetail = "SELECT qa.id, qav.id, qav.mid, qav.task_utime FROM task_qa qa LEFT JOIN task_qa_video qav ON qa.detail_id = qav.id WHERE qa.id IN (%s)" _QAVideoByTASKID = `SELECT id FROM task_qa_video WHERE aid=? AND cid=? AND task_id=?` _upQAVideoUTime = "UPDATE task_qa_video SET task_utime=? WHERE aid=? AND cid=? AND task_id=?" _delQAVideo = "DELETE FROM task_qa_video WHERE mtime 0 { var b []byte b, err = json.Marshal(dt.UPGroups) if err != nil { log.Error("InsertQAVideo json.Marshal(%v) error(%v) aid(%d) cid(%d)", dt.UPGroups, err, dt.AID, dt.CID) return } groups = string(b) } now := time.Now() res, err := tx.Exec(_inQAVideo, dt.CID, dt.AID, dt.TaskID, dt.TaskUTime, dt.Attribute, dt.MID, dt.Fans, groups, dt.ArcTitle, dt.ArcTypeID, dt.AuditStatus, dt.TagID, dt.AuditSubmit, dt.AuditDetails, now, now) if err != nil { PromeErr("arcdb: exec", "InsertQAVideo tx.Exec error(%v) aid(%d) cid(%d)", err, dt.AID, dt.CID) return } id, err = res.LastInsertId() return } //QATaskVideoByID get by id func (d *Dao) QATaskVideoByID(ctx context.Context, id int64) (q *model.QATaskVideo, err error) { var ( groups string ) q = new(model.QATaskVideo) if err = d.arcReadDB.QueryRow(ctx, _QATaskVideo, id).Scan(&q.ID, &q.State, &q.Type, &q.DetailID, &q.UID, &q.FTime, &q.CTime, &q.CID, &q.AID, &q.TaskID, &q.TaskUTime, &q.Attribute, &q.TagID, &q.ArcTitle, &q.ArcTypeID, &q.AuditStatus, &q.AuditSubmit, &q.AuditDetails, &q.MID, &q.Fans, &groups); err != nil { if err == sql.ErrNoRows { err = nil q = nil } else { PromeErr("arcReaddb: scan", "QATaskVideoByID row.Scan error(%v) id(%d)", err, id) } return } q.UPGroups = []int64{} if groups != "" { if err = json.Unmarshal([]byte(groups), &q.UPGroups); err != nil { log.Error("QATaskVideoByID json.Unmarshal(%s) error(%v) id(%d)", groups, err, id) return } } return } // QATaskVideoSimpleByID get without audit_details by id func (d *Dao) QATaskVideoSimpleByID(ctx context.Context, id int64) (q *model.QATaskVideo, err error) { var ( groups string ) q = new(model.QATaskVideo) if err = d.arcReadDB.QueryRow(ctx, _QATaskVideoSimple, id).Scan(&q.ID, &q.State, &q.Type, &q.DetailID, &q.UID, &q.FTime, &q.CTime, &q.CID, &q.AID, &q.TaskID, &q.TaskUTime, &q.Attribute, &q.TagID, &q.ArcTitle, &q.ArcTypeID, &q.AuditStatus, &q.AuditSubmit, &q.MID, &q.Fans, &groups); err != nil { if err == sql.ErrNoRows { err = nil q = nil } else { PromeErr("arcReaddb: scan", "QATaskVideoSimpleByID row.Scan error(%v) id(%d)", err, id) } return } q.UPGroups = []int64{} if groups != "" { if err = json.Unmarshal([]byte(groups), &q.UPGroups); err != nil { log.Error("QATaskVideoByID json.Unmarshal(%s) error(%v) id(%d)", groups, err, id) return } } return } //QAVideoDetail get detail id & task_utime func (d *Dao) QAVideoDetail(ctx context.Context, ids []int64) (list map[int64]map[string]int64, arr []int64, err error) { var ( idStr string rows *sql.Rows ) list = map[int64]map[string]int64{} arr = make([]int64, 0) idStr = xstr.JoinInts(ids) if rows, err = d.arcReadDB.Query(ctx, fmt.Sprintf(_QAVideoDetail, idStr)); err != nil { PromeErr("arcReaddb: query", "QAVideoDetail d.arcReadDB.Query error(%v) ids(%s)", err, idStr) return } defer rows.Close() for rows.Next() { var ( id, detailID, mid, taskUTime int64 ) if err = rows.Scan(&id, &detailID, &mid, &taskUTime); err != nil { PromeErr("arcReaddb: scan", "QAVideoDetail rows.Scan error(%v) ids(%s)", err, idStr) return } list[id] = map[string]int64{ "detail_id": detailID, "mid": mid, "task_utime": taskUTime, } arr = append(arr, mid) } return } //GetQAVideoID get id by aid & cid & taskid func (d *Dao) GetQAVideoID(ctx context.Context, aid int64, cid int64, taskID int64) (id int64, err error) { if err = d.arcDB.QueryRow(ctx, _QAVideoByTASKID, aid, cid, taskID).Scan(&id); err != nil { if err == sql.ErrNoRows { id = 0 err = nil } else { log.Error("GetQAVideoID scan error(%v) aid(%d) cid(%d) taskid(%d)", err, aid, cid, taskID) } } return } //UpdateQAVideoUTime update task_utime func (d *Dao) UpdateQAVideoUTime(ctx context.Context, aid int64, cid int64, taskID, utime int64) (err error) { if _, err = d.arcDB.Exec(ctx, _upQAVideoUTime, utime, aid, cid, taskID); err != nil { PromeErr("arcdb: exec", "UpdateQAVideoUTime error(%v) aid(%d) cid(%d) taskid(%d)", err, aid, cid, taskID) } return } //DelQAVideo 删除数据 func (d *Dao) DelQAVideo(ctx context.Context, mtime time.Time, limit int) (rows int64, err error) { var ( result xsql.Result ) if result, err = d.arcDB.Exec(ctx, _delQAVideo, mtime, limit); err != nil { PromeErr("arcdb: exec", "DelQAVideo error(%v) mtime(%v)", err, mtime) return } rows, err = result.RowsAffected() return } //DelQATask 删除数据 func (d *Dao) DelQATask(ctx context.Context, mtime time.Time, limit int) (rows int64, err error) { var ( result xsql.Result ) if result, err = d.arcDB.Exec(ctx, _delQATask, mtime, limit); err != nil { PromeErr("arcdb: exec", "DelQATask error(%v) mtime(%v)", err, mtime) return } rows, err = result.RowsAffected() return }