1234567891011121314151617181920212223242526272829303132333435363738394041424344454647 |
- 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()
- }
|