bilibili-backup/app/service/main/videoup/dao/archive/report.go
2019-04-22 02:59:20 +00:00

40 lines
1.2 KiB
Go

package archive
import (
"context"
"go-common/app/service/main/videoup/model/archive"
"go-common/library/database/sql"
"go-common/library/log"
)
const (
_inArcReportSQL = "INSERT IGNORE INTO archive_report (mid,aid,type,reason,pics,ctime,mtime) VALUES(?,?,?,?,?,?,?)"
_arcReportSQL = "SELECT aid,mid,type,reason,pics,ctime,mtime FROM archive_report WHERE aid=? AND mid=? LIMIT 1"
)
// AddArcReport insert archive_report.
func (d *Dao) AddArcReport(c context.Context, aa *archive.ArcReport) (id int64, err error) {
res, err := d.db.Exec(c, _inArcReportSQL, aa.Mid, aa.Aid, aa.Type, aa.Reason, aa.Pics, aa.CTime, aa.MTime)
if err != nil {
log.Error("_inArcReport.Exec error(%v)", err)
return
}
return res.LastInsertId()
}
// ArcReport get archive_report by aid and mid.
func (d *Dao) ArcReport(c context.Context, aid, mid int64) (aa *archive.ArcReport, err error) {
row := d.rddb.QueryRow(c, _arcReportSQL, aid, mid)
aa = &archive.ArcReport{}
if err = row.Scan(&aa.Aid, &aa.Mid, &aa.Type, &aa.Reason, &aa.Pics, &aa.CTime, &aa.MTime); err != nil {
if err == sql.ErrNoRows {
err = nil
aa = nil
} else {
log.Error("row.Scan error(%v)", err)
}
}
return
}