report.go 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. package pc
  2. import (
  3. "fmt"
  4. "hongze/hongze_yb/global"
  5. "time"
  6. )
  7. type Report struct {
  8. Id int `description:"报告Id"`
  9. AddType int `description:"新增方式:1:新增报告,2:继承报告"`
  10. ClassifyIdFirst int `description:"一级分类id"`
  11. ClassifyNameFirst string `description:"一级分类名称"`
  12. ClassifyIdSecond int `description:"二级分类id"`
  13. ClassifyNameSecond string `description:"二级分类名称"`
  14. Title string `description:"标题"`
  15. Abstract string `description:"摘要"`
  16. Author string `description:"作者"`
  17. Frequency string `description:"频度"`
  18. CreateTime string `description:"创建时间"`
  19. ModifyTime time.Time `description:"修改时间"`
  20. State int `description:"1:未发布,2:已发布"`
  21. PublishTime string `description:"发布时间"`
  22. Stage int `description:"期数"`
  23. MsgIsSend int `description:"消息是否已发送,0:否,1:是"`
  24. Content string `description:"内容"`
  25. VideoUrl string `description:"音频文件URL"`
  26. VideoName string `description:"音频文件名称"`
  27. VideoPlaySeconds string `description:"音频播放时长"`
  28. VideoSize string `description:"音频文件大小,单位M"`
  29. ContentSub string `description:"内容前两个章节"`
  30. ClassifyName string `description:"分类名称"`
  31. HasPermission int `description:"报告权限:0:无权限,1:有权限"`
  32. TitleType string `description:"标题类型,FICC或者权益"`
  33. }
  34. func GetLatestReportList() (items []*Report, err error) {
  35. sql := `SELECT * FROM report WHERE state=2 ORDER BY publish_time DESC LIMIT 3 `
  36. err = global.MYSQL["rddp"].Raw(sql).Scan(&items).Error
  37. return
  38. }
  39. func GetRecommendList(reportId, reportType, secondId int) (items []*Report, err error) {
  40. sql := `SELECT * FROM report WHERE state=2 AND id<> %v AND classify_id_second=%v `
  41. sql = fmt.Sprintf(sql, reportId, secondId)
  42. if reportType == 1 {
  43. sql += ` AND classify_name_first='权益研报' `
  44. } else {
  45. sql += ` AND classify_name_first<>'权益研报' `
  46. }
  47. sql += ` ORDER BY publish_time DESC LIMIT 3`
  48. err = global.MYSQL["rddp"].Raw(sql).Scan(&items).Error
  49. return
  50. }
  51. type LatestReport struct {
  52. Id int `orm:"column(id)" description:"报告Id" json:"_"`
  53. ClassifyNameFirst string `description:"一级分类名称" json:"classify_name_first"`
  54. ClassifyNameSecond string `description:"二级分类名称" json:"classify_name_second"`
  55. Title string `description:"标题" json:"title"`
  56. State int `description:"1:未发布,2:已发布" json:"state"`
  57. PublishTime time.Time `description:"发布时间" json:"publish_time"`
  58. Stage int `description:"期数" json:"stage"`
  59. }
  60. func GetLatestStage(classifyNames []string) (items []*LatestReport, err error) {
  61. sql := `SELECT * FROM(SELECT DISTINCT
  62. classify_name_first,
  63. id,
  64. title,
  65. state,
  66. publish_time,
  67. stage
  68. FROM
  69. report
  70. WHERE
  71. classify_name_first IN (?)
  72. AND state = 2
  73. ORDER BY
  74. publish_time DESC) t GROUP BY t.classify_name_first`
  75. err = global.MYSQL["rddp"].Raw(sql, classifyNames).Scan(&items).Error
  76. return
  77. }