report.go 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  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. Title string `description:"标题" json:"title"`
  55. State int `description:"1:未发布,2:已发布" json:"state"`
  56. PublishTime time.Time `description:"发布时间" json:"publish_time"`
  57. Stage int `description:"期数" json:"stage"`
  58. }
  59. func GetLatestStage(classifyNames []string) (items []*LatestReport, err error) {
  60. sql := `SELECT * FROM(SELECT DISTINCT
  61. classify_name_first,
  62. id,
  63. title,
  64. state,
  65. publish_time,
  66. stage
  67. FROM
  68. report
  69. WHERE
  70. classify_name_first IN (?)
  71. AND state = 2
  72. ORDER BY
  73. publish_time DESC) t GROUP BY t.classify_name_first`
  74. err = global.MYSQL["rddp"].Raw(sql, classifyNames).Scan(&items).Error
  75. return
  76. }