article_top_history_record.go 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. package models
  2. import (
  3. "github.com/beego/beego/v2/client/orm"
  4. "time"
  5. )
  6. // ArticleTopHistoryRecord 报告阅读飙升榜
  7. type ArticleTopHistoryRecord struct {
  8. Id int `orm:"column(id);pk"`
  9. ArticleId int `description:"文章ID"`
  10. Title string `description:"文章标题"`
  11. PublishDate string `description:"发布日期"`
  12. ChartPermissionId int `description:"行业ID"`
  13. PermissionName string `description:"行业名称"`
  14. Pv int `description:"PV"`
  15. CreateTime time.Time `description:"创建时间"`
  16. }
  17. func (item *ArticleTopHistoryRecord) TableName() string {
  18. return "cygx_article_top_history_record"
  19. }
  20. // GetTopReadRecordArticleListFromSource 获取阅读量排行榜源报告
  21. func GetTopReadRecordArticleListFromSource(limit int, startTime, endTime time.Time) (list []*ArticleTopHistoryRecord, err error) {
  22. sql := `SELECT
  23. a.article_id,
  24. a.title,
  25. date_format(a.publish_date, '%Y-%m-%d') AS publish_date,
  26. m.chart_permission_id,
  27. m.chart_permission_name as permission_name,
  28. COUNT(1) AS pv
  29. FROM
  30. cygx_article_history_record_all AS l
  31. JOIN cygx_article AS a ON a.article_id = l.article_id
  32. JOIN cygx_report_mapping AS m ON m.category_id = a.category_id
  33. WHERE
  34. 1 = 1
  35. AND l.platfor = 1 AND a.publish_status = 1 AND l.create_time BETWEEN ? AND ?
  36. GROUP BY
  37. l.article_id
  38. ORDER BY
  39. pv DESC,
  40. a.publish_date DESC
  41. LIMIT ?`
  42. _, err = orm.NewOrm().Raw(sql, startTime, endTime, limit).QueryRows(&list)
  43. return
  44. }
  45. // UpdateTopReadRecordArticleList 更新榜单
  46. func UpdateTopReadRecordArticleList(items []*ArticleTopHistoryRecord) (err error) {
  47. o := orm.NewOrm()
  48. tx, err := o.Begin()
  49. if err != nil {
  50. return
  51. }
  52. defer func() {
  53. if err != nil {
  54. _ = tx.Rollback()
  55. } else {
  56. _ = tx.Commit()
  57. }
  58. }()
  59. // 重置榜单
  60. sql := `DELETE FROM cygx_article_top_history_record WHERE 1 = 1 `
  61. _, err = tx.Raw(sql).Exec()
  62. if err != nil {
  63. return
  64. }
  65. // 新增今日榜单
  66. _, err = tx.InsertMulti(len(items), items)
  67. if err != nil {
  68. return
  69. }
  70. return
  71. }
  72. // GetTopReadRecordArticleListByCondition 获取阅读量排行榜
  73. func GetTopReadRecordArticleListByCondition(limit int, condition string, pars []interface{}) (list []*ArticleTopHistoryRecord, err error) {
  74. sql := `SELECT * FROM cygx_article_top_history_record WHERE 1 = 1 `
  75. if condition != `` {
  76. sql += condition
  77. }
  78. sql += ` ORDER BY pv DESC, publish_date DESC LIMIT ?`
  79. _, err = orm.NewOrm().Raw(sql, pars, limit).QueryRows(&list)
  80. return
  81. }