123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600 |
- package report
- import (
- "fmt"
- "hongze/hongze_yb/global"
- "hongze/hongze_yb/models/response"
- "hongze/hongze_yb/models/response/pc"
- "hongze/hongze_yb/utils"
- "strings"
- )
- // GetLatestClassReportsByClassifyIdSeconds 根据用户已购买的分类权限查询个分类最新的报告
- func GetLatestClassReportsByClassifyIdSeconds(classifyIdSeconds []int) (reportList []*Report, err error) {
- sql := `SELECT t1.id,
- t1.classify_id_first,
- t1.classify_id_second,
- t1.stage,
- t1.title,
- t1.classify_name_first,
- t1.classify_name_second,
- t1.publish_time
- FROM report t1
- INNER JOIN
- (
- SELECT classify_id_first, max( publish_time ) AS max_publish_time
- FROM report
- WHERE
- state IN (2, 6)
- AND classify_name_first !="权益研报"
- AND classify_id_second IN ?
- GROUP BY
- classify_id_first
- ) t2
- ON t1.classify_id_first = t2.classify_id_first AND
- t1.publish_time = t2.max_publish_time
- WHERE t1.state IN (2, 6)
- AND t1.classify_name_first !="权益研报"
- AND t1.classify_id_second IN ?`
- err = global.MYSQL["rddp"].Raw(sql, classifyIdSeconds, classifyIdSeconds).Scan(&reportList).Error
- return
- }
- // GetReportsByClassifyIdSecondsAndDate 根据时间和报告分类筛选出合适的记录
- func GetReportsByClassifyIdSecondsAndDate(classifyIdSeconds []int, publishTime string) (reportList []*Report, err error) {
- err = global.MYSQL["rddp"].Model(Report{}).
- Select("id, classify_name_first").
- Where("classify_id_second in (?) and state IN (2, 6) and publish_time > ? ", classifyIdSeconds, publishTime).Scan(&reportList).Error
- return
- }
- // GetListByIDsAndClassifyIdFirst 分页查询
- func GetListByIDsAndClassifyIdFirst(ids []int, classifyIdFirst int, offset, limit int) (reportList []*Report, err error) {
- err = global.MYSQL["rddp"].Model(Report{}).
- Select("id, classify_id_first, classify_name_first, classify_id_second, classify_name_second, title, stage, publish_time").
- Where("id in (?) and classify_id_first=? and state IN (2, 6) ", ids, classifyIdFirst).
- Order("publish_time desc, id desc").
- Offset(offset).
- Limit(limit).
- Scan(&reportList).Error
- return
- }
- // GetListCountByIDsAndClassifyIdFirst 分页查询
- func GetListCountByIDsAndClassifyIdFirst(ids []int, classifyIdFirst int) (total int64, err error) {
- err = global.MYSQL["rddp"].Model(Report{}).
- Select("id, classify_id_first, classify_name_first, classify_id_second, classify_name_second, title, stage, publish_time").
- Where("id in (?) and classify_id_first=? and state IN (2, 6) ", ids, classifyIdFirst).
- Count(&total).Error
- return
- }
- // GetListByClassifyIdSeconds 分页查询
- func GetListByClassifyIdSeconds(classifyIdSeconds []int, offset, limit int) (reportList []*Report, err error) {
- err = global.MYSQL["rddp"].Model(Report{}).
- Select("id, classify_id_first, classify_name_first, classify_id_second, classify_name_second, title, stage, publish_time").
- Where("classify_id_second in (?) and state IN (2, 6) ", classifyIdSeconds).
- Order("publish_time desc, id desc").
- Offset(offset).
- Limit(limit).
- Scan(&reportList).Error
- return
- }
- // GetListCountByClassifyIdSeconds
- func GetListCountByClassifyIdSeconds(classifyIdSeconds []int) (total int64, err error) {
- err = global.MYSQL["rddp"].Model(Report{}).
- Select("id, classify_id_first, classify_name_first, classify_id_second, classify_name_second, title, stage, publish_time").
- Where("classify_id_second in (?) and state IN (2, 6) ", classifyIdSeconds).
- Count(&total).Error
- return
- }
- // GetListByClassifyIdFirst 按照类型分页查询
- func GetListByClassifyIdFirst(classifyIdFirst int, offset, limit int) (reportList []*Report, err error) {
- err = global.MYSQL["rddp"].Model(Report{}).
- Select("id, classify_id_first, classify_name_first, classify_id_second, classify_name_second, title, stage, publish_time").
- Where("classify_id_first=? and state IN (2, 6) ", classifyIdFirst).
- Order("publish_time desc, id desc").
- Offset(offset).
- Limit(limit).
- Scan(&reportList).Error
- return
- }
- // GetListCountByClassifyIdFirst 按照类型查询报告总数
- func GetListCountByClassifyIdFirst(classifyIdFirst int) (total int64, err error) {
- err = global.MYSQL["rddp"].Model(Report{}).
- Select("id, classify_id_first, classify_name_first, classify_id_second, classify_name_second, title, stage, publish_time").
- Where("classify_id_first=? and state IN (2, 6) ", classifyIdFirst).
- Count(&total).Error
- return
- }
- // GetLatestByReportIds 根据ids获取报告
- func GetLatestByReportIds(ids []int) (item *Report, err error) {
- err = global.MYSQL["rddp"].Where("id in ? and state IN (2, 6)", ids).Order("publish_time desc, id desc").First(&item).Error
- if err == utils.ErrNoRow {
- err = nil
- }
- return
- }
- // GetPublishByReportId 根据id获取报告
- func GetPublishByReportId(id int) (item *Report, err error) {
- err = global.MYSQL["rddp"].Where("id = ? and state IN (2, 6)", id).First(&item).Error
- if err == utils.ErrNoRow {
- err = nil
- }
- return
- }
- // GetByReportId 根据id获取报告
- func GetByReportId(id int) (item *Report, err error) {
- err = global.MYSQL["rddp"].Where("id = ? ", id).First(&item).Error
- if err == utils.ErrNoRow {
- err = nil
- }
- return
- }
- // GetByReportIds 根据id获取报告
- func GetByReportIds(ids []int) (list []*Report, err error) {
- err = global.MYSQL["rddp"].Model(Report{}).
- Where("id in (?) and state IN (2, 6)", ids).
- Select("id, create_time").
- Scan(&list).Error
- if err == utils.ErrNoRow {
- err = nil
- }
- return
- }
- // GetLatestDay 获取最新的晨报
- func GetLatestDay() (item *Report, err error) {
- err = global.MYSQL["rddp"].Where("state = 2 and classify_name_first= '晨报'").Order("publish_time desc, id desc").First(&item).Error
- if err == utils.ErrNoRow {
- err = nil
- }
- return
- }
- // GetLatestReportsByClassifyIdFirst 查询当前一级分类下,二级分类中,最新的报告
- func GetLatestReportsByClassifyIdFirst(classifyIdFirst int, classifyIdSeconds []int) (reportList []*Report, err error) {
- sql := `
- SELECT t1.id,
- t1.classify_id_first,
- t1.classify_id_second,
- t1.stage,
- t1.classify_name_first,
- t1.classify_name_second,
- t1.publish_time
- FROM report t1
- INNER JOIN
- (
- SELECT classify_id_first, classify_id_second, max( publish_time ) AS max_publish_time
- FROM report
- WHERE
- state IN (2, 6)
- AND classify_id_first = ?
- AND classify_id_second IN ?
- GROUP BY
- classify_id_second
- ) t2
- ON t1.classify_id_second = t2.classify_id_second AND
- t1.classify_id_first = t2.classify_id_first AND
- t1.publish_time = t2.max_publish_time
- WHERE t1.state IN (2, 6)
- AND t1.classify_id_first = ?
- AND t1.classify_id_second IN ?`
- err = global.MYSQL["rddp"].Raw(sql, classifyIdFirst, classifyIdSeconds, classifyIdFirst, classifyIdSeconds).Scan(&reportList).Error
- return
- }
- // GetReportListByCondition 获取报告列表
- func GetReportListByCondition(condition string, pars []interface{}) (list []*Report, err error) {
- err = global.MYSQL["rddp"].Select("id").Model(Report{}).Where(condition, pars...).
- Scan(&list).Error
- return
- }
- // GetListByClassifyIdSecond 按照二级类型分页查询
- func GetListByClassifyIdSecond(classifyIdSecond int, offset, limit int) (reportList []*Report, err error) {
- err = global.MYSQL["rddp"].Model(Report{}).
- Select("id, classify_id_first, classify_name_first, classify_id_second, classify_name_second, title, stage, publish_time, author, video_name, video_url, video_play_seconds, abstract").
- Where("classify_id_second = ? and state IN (2, 6) ", classifyIdSecond).
- Order("publish_time desc, id desc").
- Offset(offset).
- Limit(limit).
- Scan(&reportList).Error
- if err == utils.ErrNoRow {
- err = nil
- }
- return
- }
- // GetListCountByClassifyIdSecond 按照二级分类总条数
- func GetListCountByClassifyIdSecond(classifyIdSecond int) (total int64, err error) {
- err = global.MYSQL["rddp"].Model(Report{}).
- Where("classify_id_second=? and state IN (2, 6) ", classifyIdSecond).Count(&total).Error
- if err == utils.ErrNoRow {
- err = nil
- }
- return
- }
- // GetReportList 获取报告列表
- func GetReportList(condition string, pars []interface{}, offset, limit int) (list []*Report, err error) {
- err = global.MYSQL["rddp"].Model(Report{}).
- Select("id, classify_id_first, classify_name_first, classify_id_second, classify_name_second,classify_id_third, classify_name_third, title, stage, publish_time, author, create_time, video_url, video_name, video_play_seconds, abstract,has_chapter,head_img,end_img,head_resource_id,end_resource_id").
- Where(condition, pars...).
- Order("publish_time desc, id desc").
- Offset(offset).
- Limit(limit).
- Scan(&list).Error
- return
- }
- // GetReportListCount 获取报告总数
- func GetReportListCount(condition string, pars []interface{}) (total int64, err error) {
- err = global.MYSQL["rddp"].Model(Report{}).Where(condition, pars...).
- Count(&total).Error
- return
- }
- // GetReportCollectListByPermission 根据权限相关的分类查询报告和章节
- func GetReportCollectListByPermission(classifyIdSeconds []int, typeIds []int, offset, limit int) (list []*response.ReportCollectListItem, err error) {
- sql := `( SELECT
- id AS report_id,
- 0 AS report_chapter_id,
- classify_id_first,
- classify_id_second,
- classify_name_first,
- classify_name_second,
- 0 as report_chapter_type_id,
- title,
- content_sub,
- publish_time
- FROM
- report
- WHERE
- classify_name_first != "晨报"
- AND classify_name_first != "周报"
- AND classify_id_second in ?
- AND state IN (2, 6)
- )
- UNION
-
- ( SELECT
- report_id,
- report_chapter_id,
- classify_id_first,
- 0 as classify_id_second,
- classify_name_first,
- null as classify_name_second,
- type_id as report_chapter_type_id,
- title,
- content_sub,
- publish_time
- FROM
- report_chapter
- WHERE
- publish_state = 2
- AND type_id in ?
- )
- ORDER BY publish_time DESC, report_id desc LIMIT ? OFFSET ?
- `
- err = global.MYSQL["rddp"].Raw(sql, classifyIdSeconds, typeIds, limit, offset).Scan(&list).Error
- return
- }
- // GetReportCollectCountByPermission 查询汇总报告总页数
- func GetReportCollectCountByPermission(classifyIdSeconds []int, typeIds []int) (total int64, err error) {
- sql := `select count(*) from ( ( SELECT
- id AS report_id,
- 0 AS report_chapter_id
- FROM
- report
- WHERE
- classify_name_first != "晨报"
- AND classify_name_first != "周报"
- AND classify_id_second in ?
- AND state IN (2, 6)
- )
- UNION
-
- ( SELECT
- report_id,
- report_chapter_id
- FROM
- report_chapter
- WHERE
- publish_state = 2
- AND type_id in ?
- )
- ) as ru
- `
- err = global.MYSQL["rddp"].Raw(sql, classifyIdSeconds, typeIds).Count(&total).Error
- return
- }
- // GetLatestReportByPermission 根据权限相关的分类查询最新的三篇专栏报告
- func GetLatestReportByPermission(classifyIdSeconds []int) (list []*pc.LatestReport, err error) {
- sql := `SELECT
- id AS report_id,
- 0 AS report_chapter_id,
- classify_id_first,
- classify_id_second,
- classify_name_first,
- classify_name_second,
- 0 as report_chapter_type_id,
- title,
- content_sub,
- stage,
- publish_time
- FROM
- report
- WHERE
- classify_name_first != "晨报"
- AND classify_name_first != "周报"
- AND classify_id_second in ?
- AND state IN (2, 6)
- ORDER BY publish_time DESC LIMIT 3
- `
- err = global.MYSQL["rddp"].Raw(sql, classifyIdSeconds).Scan(&list).Error
- return
- }
- // GetLatestReport 获取最新专栏信息
- func GetLatestReport() (list *pc.LatestReport, err error) {
- sql := `SELECT
- r.id AS report_id,
- 0 AS report_chapter_id,
- classify_id_first,
- classify_id_second,
- classify_name_first,
- classify_name_second,
- 0 as report_chapter_type_id,
- title,
- content_sub,
- stage,
- publish_time
- FROM
- report AS r
- INNER JOIN
- classify AS c
- WHERE
- r.classify_name_first = c.classify_name
- AND c.show_type = 2
- AND c.is_show = 1
- AND c.enabled = 1
- AND state IN (2, 6)
- ORDER BY publish_time DESC LIMIT 1
- `
- err = global.MYSQL["rddp"].Raw(sql).First(&list).Error
- return
- }
- // GetReportByOldReportId 根据老后台的research_report_id查找新的报告ID
- func GetReportByOldReportId(oldReportId uint64) (item *Report, err error) {
- err = global.MYSQL["rddp"].Model(Report{}).
- Where("old_report_id=?", oldReportId).First(&item).Error
- if err == utils.ErrNoRow {
- err = nil
- }
- return
- }
- func GetLatestReportByClassifyName(firstName string, secondId int) (items *pc.LatestReportBanner, err error) {
- sql := `SELECT
- a.id AS report_id,
- classify_name_second,
- classify_id_second,
- classify_name_first,
- classify_id_first,
- author,
- stage,
- report_author,
- vip_title
- FROM
- report as a
- JOIN classify as b
- WHERE
- a.state IN (2, 6)
- AND a.classify_name_first = "%v"
- AND a.classify_id_second = %v
- AND a.classify_id_second = b.id
- ORDER BY
- publish_time DESC `
- sql = fmt.Sprintf(sql, firstName, secondId)
- err = global.MYSQL["rddp"].Raw(sql).First(&items).Error
- return
- }
- // GetCommoditiesReportCollectListByPermission 根据权限相关的分类查询大宗商品报告
- func GetCommoditiesReportCollectListByPermission(classifyIdSeconds []int, offset, limit int) (list []*Report, err error) {
- sql := ` SELECT
- id, classify_id_first, classify_name_first, classify_id_second, classify_name_second, title, stage, publish_time, author, create_time, video_url, video_name, video_play_seconds, abstract
- FROM
- report
- WHERE
- classify_name_first != "晨报"
- AND classify_name_first != "周报"
- AND classify_id_second in ?
- AND state IN (2, 6)
- ORDER BY publish_time DESC, id desc LIMIT ? OFFSET ?
- `
- err = global.MYSQL["rddp"].Raw(sql, classifyIdSeconds, limit, offset).Scan(&list).Error
- return
- }
- // GetCommoditiesReportCollectCountByPermission 查询大宗商品报告总页数
- func GetCommoditiesReportCollectCountByPermission(classifyIdSeconds []int) (total int64, err error) {
- sql := `select count(*)
- FROM
- report
- WHERE
- classify_name_first != "晨报"
- AND classify_name_first != "周报"
- AND classify_id_second in ?
- AND state IN (2, 6)
-
- `
- err = global.MYSQL["rddp"].Raw(sql, classifyIdSeconds).Count(&total).Error
- return
- }
- // GetListByReportIds 根据IDs获取列表
- func GetListByReportIds(reportIds []int) (list []*Report, err error) {
- var where string
- where = `state IN (2, 6)`
- if len(reportIds) > 0 {
- where += ` AND id IN (?)`
- }
- err = global.MYSQL["rddp"].Model(Report{}).
- Where(where, reportIds).
- Order("id asc").
- Scan(&list).Error
- return
- }
- // GetReportCollectListByPermissionV1
- // @Description: 根据权限相关的分类查询报告和章节
- // @author: Roc
- // @datetime 2024-06-21 10:24:14
- // @param chartPermissionId int
- // @param classifyIdSeconds []int
- // @param offset int
- // @param limit int
- // @return list []*response.ReportCollectListItem
- // @return err error
- func GetReportCollectListByPermissionV1(chartPermissionId int, firstClassifyIdList, secondClassifyIdList, thirdClassifyIdList []int, offset, limit int) (list []*response.ReportCollectListItem, err error) {
- conditionList := make([]string, 0)
- pars := make([]interface{}, 0)
- if len(firstClassifyIdList) > 0 {
- conditionList = append(conditionList, "classify_id_first in ?")
- pars = append(pars, firstClassifyIdList)
- }
- if len(secondClassifyIdList) > 0 {
- conditionList = append(conditionList, "classify_id_second in ?")
- pars = append(pars, secondClassifyIdList)
- }
- if len(thirdClassifyIdList) > 0 {
- conditionList = append(conditionList, "classify_id_third in ?")
- pars = append(pars, thirdClassifyIdList)
- }
- condition := " classify_id_first = 0 "
- if len(conditionList) > 0 {
- condition = strings.Join(conditionList, " OR ")
- }
- pars = append(pars, chartPermissionId, limit, offset)
- sql := `( SELECT
- id AS report_id,
- 0 AS report_chapter_id,
- classify_id_first,
- classify_id_second,
- classify_name_first,
- classify_name_second,
- 0 as report_chapter_type_id,
- title,
- content_sub,
- publish_time
- FROM
- report
- WHERE
- has_chapter != 1
- AND ( ` + condition + ` )
- AND state IN (2, 6)
- )
- UNION
-
- ( SELECT
- a.report_id,
- a.report_chapter_id,
- a.classify_id_first,
- 0 as classify_id_second,
- a.classify_name_first,
- null as classify_name_second,
- a.type_id as report_chapter_type_id,
- a.title,
- a.content_sub,
- a.publish_time
- FROM
- report_chapter AS a
- JOIN report_chapter_permission_mapping AS b on a.report_chapter_id=b.report_chapter_id
- WHERE
- a.publish_state = 2
- AND b.chart_permission_id = ?
- )
- ORDER BY publish_time DESC, report_id desc LIMIT ? OFFSET ?
- `
- err = global.MYSQL["rddp"].Raw(sql, pars...).Scan(&list).Error
- return
- }
- // GetReportCollectCountByPermission 查询汇总报告总页数
- func GetReportCollectCountByPermissionV1(chartPermissionId int, classifyIdSeconds []int) (total int64, err error) {
- sql := `select count(*) from ( (( SELECT
- id AS report_id,
- 0 AS report_chapter_id
- FROM
- report
- WHERE
- has_chapter != 1
- AND classify_id_second in ?
- AND state IN (2, 6)
- )
- UNION
-
- ( SELECT
- a.report_id,
- a.report_chapter_id
- FROM
- report_chapter AS a
- JOIN report_chapter_permission_mapping AS b on a.report_chapter_id=b.report_chapter_id
- WHERE
- a.publish_state = 2
- AND b.chart_permission_id = ?
- )
- )
-
- ) as ru
- `
- err = global.MYSQL["rddp"].Raw(sql, classifyIdSeconds, chartPermissionId).Count(&total).Error
- return
- }
- // GetLatestReportByClassifyId
- // @Description: 根据分类id获取最近一期报告
- // @author: Roc
- // @datetime 2024-06-24 14:10:05
- // @param firstId int
- // @param secondId int
- // @param thirdId int
- // @return items *pc.LatestReportBanner
- // @return err error
- func GetLatestReportByClassifyId(firstId, secondId, thirdId int) (items *pc.LatestReportBanner, err error) {
- sql := `SELECT
- a.id AS report_id,
- classify_name_second,
- classify_id_second,
- classify_name_first,
- classify_id_first,
- author,
- stage
- FROM
- report as a
- WHERE
- a.state IN (2, 6)
- AND a.classify_id_first = ?
- AND a.classify_id_second = ?
- AND a.classify_id_third = ?
- ORDER BY
- publish_time DESC `
- err = global.MYSQL["rddp"].Raw(sql, firstId, secondId, thirdId).First(&items).Error
- return
- }
|