mysql.go 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. package weeklyhonor
  2. import (
  3. "context"
  4. model "go-common/app/interface/main/creative/model/weeklyhonor"
  5. "go-common/library/log"
  6. )
  7. const (
  8. _honorLogsSQL = `SELECT id,mid,hid,count,ctime,mtime FROM weeklyhonor WHERE mid=?`
  9. _upsertCountSQL = `INSERT INTO weeklyhonor (mid,hid,count) VALUES (?,?,?) ON DUPLICATE KEY UPDATE count=count+1`
  10. _upsertClickCountSQL = `INSERT INTO weeklyhonor_click (mid,count) VALUES (?,?) ON DUPLICATE KEY UPDATE count=count+1`
  11. )
  12. // pingMySQL check mysql connection.
  13. func (d *Dao) pingMySQL(c context.Context) error {
  14. return d.db.Ping(c)
  15. }
  16. // HonorLogs .
  17. func (d *Dao) HonorLogs(c context.Context, mid int64) (hls map[int]*model.HonorLog, err error) {
  18. rows, err := d.db.Query(c, _honorLogsSQL, mid)
  19. if err != nil {
  20. log.Error("d.db.Query(%s,%d) error(%v)", _honorLogsSQL, mid, err)
  21. return
  22. }
  23. defer rows.Close()
  24. hls = make(map[int]*model.HonorLog)
  25. for rows.Next() {
  26. h := new(model.HonorLog)
  27. if err = rows.Scan(&h.ID, &h.MID, &h.HID, &h.Count, &h.CTime, &h.MTime); err != nil {
  28. log.Error("rows.Scan error(%v)", err)
  29. return
  30. }
  31. hls[h.HID] = h
  32. }
  33. err = rows.Err()
  34. return
  35. }
  36. // UpsertCount .
  37. func (d *Dao) UpsertCount(c context.Context, mid int64, hid int) (err error) {
  38. if _, err = d.db.Exec(c, _upsertCountSQL, mid, hid, 1); err != nil {
  39. log.Error("d.db.Exec(%s,%d,%d) error(%v)", _upsertCountSQL, mid, hid, err)
  40. return
  41. }
  42. return
  43. }
  44. // UpsertClickCount log weeklyhonor click count
  45. func (d *Dao) UpsertClickCount(c context.Context, mid int64) (err error) {
  46. if _, err = d.db.Exec(c, _upsertClickCountSQL, mid, 1); err != nil {
  47. log.Error("d.db.Exec(%s,%d) error(%v)", _upsertClickCountSQL, mid, err)
  48. return
  49. }
  50. return
  51. }