go-common/app/job/main/growup/dao/task_status.go

48 lines
1.3 KiB
Go
Raw Normal View History

2019-04-22 10:49:16 +00:00
package dao
import (
"context"
"database/sql"
"fmt"
"go-common/library/log"
)
const (
_taskStatus = "SELECT status FROM task_status WHERE date=? AND type=?"
_upTaskStatus = "UPDATE task_status SET status=? WHERE date=? AND type=?"
_inTaskStatus = "INSERT INTO task_status(type, date, status, message) VALUES (%d, '%s', %d, '%s') ON DUPLICATE KEY UPDATE status=VALUES(status), message=VALUES(message)"
)
// TaskStatus get task status
func (d *Dao) TaskStatus(c context.Context, date string, typ int) (status int, err error) {
row := d.db.QueryRow(c, _taskStatus, date, typ)
if err = row.Scan(&status); err != nil {
if err == sql.ErrNoRows {
err = nil
} else {
log.Error("dao.GetTaskStatus error(%v)", err)
}
}
return
}
// UpdateTaskStatus update task status
func (d *Dao) UpdateTaskStatus(c context.Context, date string, typ int, status int) (rows int64, err error) {
res, err := d.db.Exec(c, _upTaskStatus, status, date, typ)
if err != nil {
return
}
return res.RowsAffected()
}
// InsertTaskStatus insert task status
func (d *Dao) InsertTaskStatus(c context.Context, typ, status int, date, message string) (rows int64, err error) {
res, err := d.db.Exec(c, fmt.Sprintf(_inTaskStatus, typ, date, status, message))
if err != nil {
return
}
return res.RowsAffected()
}