123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639 |
- package data
- import (
- "context"
- "errors"
- "fmt"
- "hongze/hongze_task/models/data_manage"
- "hongze/hongze_task/utils"
- "rdluck_tools/http"
- "strconv"
- "sync"
- "time"
- )
- //刷新同花顺数据
- func RefreshDataFromThs(wg *sync.WaitGroup) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromThs Err:" + err.Error())
- go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "RefreshDataFromThs ErrMsg:"+err.Error(), utils.EmailSendToUsers)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_THS)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- var endDate string
- endDate = time.Now().AddDate(utils.DATA_END_DATE_LIMIT, 0, 0).Format(utils.FormatDate)
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- err = SyncEdbDataByThs(int64(v.EdbInfoId), v.EdbCode, startDate, endDate)
- if err != nil {
- return errors.New("SyncEdbDataByThs:" + err.Error())
- }
- item, err := data_manage.GetEdbInfoMaxAndMinInfo(v.Source, v.EdbCode)
- if err != nil {
- return err
- }
- if item != nil {
- err = data_manage.ModifyEdbInfoMaxAndMinInfo(v.EdbInfoId, item)
- if err != nil {
- return err
- }
- }
- //minDate, maxDate, err := data.GetEdbDataThsMaxOrMinDate(v.EdbInfoId)
- //if err != nil {
- // return errors.New("GetEdbDataThsMaxOrMinDate:" + err.Error())
- //}
- //fmt.Println("minDate:" + minDate + ";maxDate:" + maxDate)
- //err = data.ModifyEdbDataInfoDate(v.EdbInfoId, maxDate)
- //if err != nil {
- // return errors.New("ModifyEdbDataInfoDate:" + err.Error())
- //}
- }
- return err
- }
- //刷新万得数据
- func RefreshDataFromWind(wg *sync.WaitGroup) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromWind Err:" + err.Error())
- go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "RefreshDataFromWind ErrMsg:"+err.Error(), utils.EmailSendToUsers)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_WIND)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return err
- }
- var endDate string
- endDate = time.Now().Format(utils.FormatDate)
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- err = SyncEdbDataByWind(int64(v.EdbInfoId), v.EdbCode, startDate, endDate)
- if err != nil {
- return err
- }
- item, err := data_manage.GetEdbInfoMaxAndMinInfo(v.Source, v.EdbCode)
- if err != nil {
- return err
- }
- if item != nil {
- err = data_manage.ModifyEdbInfoMaxAndMinInfo(v.EdbInfoId, item)
- if err != nil {
- return err
- }
- }
- }
- return err
- }
- //刷新彭博数据
- func RefreshDataFromPb(wg *sync.WaitGroup) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromPb Err:" + err.Error())
- go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "RefreshDataFromPb ErrMsg:"+err.Error(), utils.EmailSendToUsers)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_PB)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- var endDate string
- endDate = time.Now().AddDate(utils.DATA_END_DATE_LIMIT, 0, 0).Format(utils.FormatDateUnSpace)
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDateUnSpace)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDateUnSpace)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDateUnSpace)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDateUnSpace)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDateUnSpace)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDateUnSpace)
- }
- err = SyncEdbDataByPb(int64(v.EdbInfoId), v.EdbCode, startDate, endDate)
- if err != nil {
- return errors.New("SyncEdbDataByPb:" + err.Error())
- }
- item, err := data_manage.GetEdbInfoMaxAndMinInfo(v.Source, v.EdbCode)
- if err != nil {
- return err
- }
- if item != nil {
- err = data_manage.ModifyEdbInfoMaxAndMinInfo(v.EdbInfoId, item)
- if err != nil {
- return err
- }
- }
- //minDate, maxDate, err := data.GetEdbDataPbMaxOrMinDate(v.EdbInfoId)
- //if err != nil {
- // return errors.New("GetEdbDataThsMaxOrMinDate:" + err.Error())
- //}
- //fmt.Println("minDate:" + minDate + ";maxDate:" + maxDate)
- //err = data.ModifyEdbDataInfoDate(v.EdbInfoId, maxDate)
- //if err != nil {
- // return errors.New("ModifyEdbDataInfoDate:" + err.Error())
- //}
- }
- return err
- }
- func CheckDataInterface(cont context.Context) (err error) {
- go func() {
- checkUrl := utils.Hz_Data_Url + `hz_server`
- body, err := http.Get(checkUrl)
- if err != nil {
- go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"检测数据接口:失败提醒", "CheckDataInterface ErrMsg:"+err.Error(), utils.EmailSendToUsers)
- }
- result := string(body)
- if result != "1" {
- go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"检测数据接口:失败提醒", "CheckDataInterface ErrMsg:"+string(body), utils.EmailSendToUsers)
- }
- //阿里服务器监听
- checkUrl2 := utils.Hz_Server_Data_Url + `hz_server`
- body, err = http.Get(checkUrl2)
- if err != nil {
- go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"检测服务器数据接口:失败提醒", "CheckDataInterface ErrMsg:"+err.Error(), utils.EmailSendToUsers)
- }
- result = string(body)
- if result != "1" {
- go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"检测服务器数据接口:失败提醒", "CheckDataInterface ErrMsg:"+string(body), utils.EmailSendToUsers)
- }
- }()
- return
- }
- func CheckPbDataInterface(cont context.Context) (err error) {
- go func() {
- checkUrl := utils.Hz_Data_PB_Url + `hz_server`
- body, err := http.Get(checkUrl)
- if err != nil {
- go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"检测数据接口:失败提醒", "CheckPbDataInterface ErrMsg:"+err.Error(), utils.EmailSendToUsers)
- }
- result := string(body)
- if result != "1" {
- go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"检测数据接口:失败提醒", "CheckPbDataInterface ErrMsg:"+string(body), utils.EmailSendToUsers)
- }
- }()
- return
- }
- //刷新所有计算指标
- func RefreshDataFromCalculateAll() (err error) {
- defer func() {
- if err != nil {
- utils.FileLog.Info("RefreshDataFromCalculateAll Err:" + err.Error())
- go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "RefreshDataFromCalculateAll ErrMsg:"+err.Error(), utils.EmailSendToUsers)
- }
- }()
- var condition string
- var pars []interface{}
- condition += " AND edb_type=? "
- pars = append(pars, 2)
- //condition += " AND source=? "
- //pars = append(pars, utils.DATA_SOURCE_CALCULATE_BP)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return err
- }
- for _, v := range items {
- edbInfoId := v.EdbInfoId
- edbCode := v.EdbCode
- source := v.Source
- fmt.Println(v.EdbInfoId, v.EdbCode, v.EdbName, v.SourceName)
- if source == utils.DATA_SOURCE_CALCULATE {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- endDate := time.Now().Format(utils.FormatDate)
- var edbInfoIdBytes []string
- calculateMap, err := data_manage.GetEdbInfoCalculateDetail(int(v.EdbInfoId))
- if err != nil {
- return errors.New("GetEdbInfoCalculateDetail Err:" + err.Error())
- }
- var formulaStr string
- edbInfoList := make([]*data_manage.EdbInfo, 0)
- for _, v := range calculateMap {
- formulaStr += v.FromTag + ","
- edbInfoIdBytes = append(edbInfoIdBytes, v.FromTag)
- edbInfo, _ := data_manage.GetEdbInfoById(v.FromEdbInfoId)
- edbInfoList = append(edbInfoList, edbInfo)
- }
- endDate = ""
- err = RefreshCalculate(edbInfoList, edbInfoId, edbCode, v.CalculateFormula, startDate, endDate, edbInfoIdBytes)
- if err != nil {
- return errors.New("RefreshCalculate Err:" + err.Error())
- }
- } else if source == utils.DATA_SOURCE_CALCULATE_LJZZY {
- calculateLjzzy, err := data_manage.GetEdbInfoCalculateLjzzyDetail(edbInfoId)
- if err != nil {
- return errors.New("GetEdbInfoCalculateLjzzyDetail Err:" + err.Error())
- }
- fromEdbInfo, err := data_manage.GetEdbInfoById(calculateLjzzy.FromEdbInfoId)
- if err != nil {
- return errors.New("GetEdbInfoById Err:" + err.Error())
- }
- year := time.Now().Year() - 1
- startDate := strconv.Itoa(year) + "-01" + "-01"
- endDate := ""//time.Now().Format(utils.FormatDate)
- err = data_manage.RefreshCalculateLjzzy(edbInfoId, fromEdbInfo, edbCode, startDate, endDate)
- if err != nil {
- return errors.New("RefreshCalculateLjzzy Err:" + err.Error())
- }
- } else if source == utils.DATA_SOURCE_CALCULATE_TBZ {
- calculateTbz, err := data_manage.GetEdbInfoCalculateTbzDetail(edbInfoId)
- if err != nil {
- return errors.New("GetEdbInfoCalculateTbzDetail Err:" + err.Error())
- }
- fromEdbInfo, err := data_manage.GetEdbInfoById(calculateTbz.FromEdbInfoId)
- if err != nil {
- return errors.New("GetEdbInfoById Err:" + err.Error())
- }
- startDate := time.Now().AddDate(-2, -2, 0).Format(utils.FormatDate)
- endDate := ""//time.Now().Format(utils.FormatDate)
- err = data_manage.RefreshCalculateTbz(edbInfoId, fromEdbInfo, calculateTbz.EdbCode, startDate, endDate)
- if err != nil {
- return errors.New("RefreshCalculateTbz Err:" + err.Error())
- }
- } else if source == utils.DATA_SOURCE_CALCULATE_TCZ {
- calculateTcz, err := data_manage.GetEdbInfoCalculateTczDetail(edbInfoId)
- if err != nil {
- return errors.New("GetEdbInfoCalculateTczDetail Err:" + err.Error())
- }
- fromEdbInfo, err := data_manage.GetEdbInfoById(calculateTcz.FromEdbInfoId)
- if err != nil {
- return errors.New("GetEdbInfoById Err:" + err.Error())
- }
- startDate := time.Now().AddDate(-2, -2, 0).Format(utils.FormatDate)
- endDate := ""//time.Now().Format(utils.FormatDate)
- err = data_manage.RefreshCalculateTcz(edbInfoId, fromEdbInfo, calculateTcz.EdbCode, startDate, endDate)
- if err != nil {
- return errors.New("RefreshCalculateTcz Err:" + err.Error())
- }
- } else if source == utils.DATA_SOURCE_CALCULATE_NSZYDPJJS {
- calculateNszydpjjs, err := data_manage.GetEdbInfoCalculateNszydpjjsDetail(edbInfoId)
- if err != nil {
- return errors.New("GetEdbInfoCalculateNszydpjjsDetail Err:" + err.Error())
- }
- fromEdbInfo, err := data_manage.GetEdbInfoById(calculateNszydpjjs.FromEdbInfoId)
- if err != nil {
- return errors.New("GetEdbInfoById Err:" + err.Error())
- }
- formulaInt, _ := strconv.Atoi(v.CalculateFormula)
- err = data_manage.RefreshCalculateNszydpjjs(edbInfoId, v.Source, formulaInt, fromEdbInfo, calculateNszydpjjs.EdbCode)
- if err != nil {
- return errors.New("RefreshCalculateNszydpjjs Err:" + err.Error())
- }
- } else if source == utils.DATA_SOURCE_CALCULATE_HBZ {
- calculateHbz, err := data_manage.GetEdbInfoCalculateHbzDetail(edbInfoId)
- if err != nil {
- return errors.New("GetEdbInfoCalculateHbzDetail Err:" + err.Error())
- }
- fromEdbInfo, err := data_manage.GetEdbInfoById(calculateHbz.FromEdbInfoId)
- if err != nil {
- return errors.New("GetEdbInfoById Err:" + err.Error())
- }
- startDate := time.Now().AddDate(-2, -2, 0).Format(utils.FormatDate)
- endDate := ""//time.Now().Format(utils.FormatDate)
- err = data_manage.RefreshCalculateHbz(edbInfoId, source, fromEdbInfo, calculateHbz.EdbCode, startDate, endDate)
- if err != nil {
- return errors.New("RefreshCalculateTbz Err:" + err.Error())
- }
- } else if source == utils.DATA_SOURCE_CALCULATE_HCZ {
- calculateHcz, err := data_manage.GetEdbInfoCalculateHczDetail(edbInfoId)
- if err != nil {
- return errors.New("GetEdbInfoCalculateHczDetail Err:" + err.Error())
- }
- fromEdbInfo, err := data_manage.GetEdbInfoById(calculateHcz.FromEdbInfoId)
- if err != nil {
- return errors.New("GetEdbInfoById Err:" + err.Error())
- }
- startDate := time.Now().AddDate(-2, -2, 0).Format(utils.FormatDate)
- endDate := ""//time.Now().Format(utils.FormatDate)
- err = data_manage.RefreshCalculateHcz(edbInfoId, source, fromEdbInfo, calculateHcz.EdbCode, startDate, endDate)
- if err != nil {
- return errors.New("RefreshCalculateTbz Err:" + err.Error())
- }
- } else if source == utils.DATA_SOURCE_CALCULATE_BP {
- calculateBp, err := data_manage.GetEdbInfoCalculateBpDetail(edbInfoId)
- if err != nil && err.Error() != utils.ErrNoRow() {
- return errors.New("GetEdbInfoCalculateBpDetail Err:" + err.Error())
- }
- if calculateBp != nil {
- fromEdbInfo, err := data_manage.GetEdbInfoById(calculateBp.FromEdbInfoId)
- if err != nil {
- return errors.New("GetEdbInfoById Err:" + err.Error())
- }
- startDate := time.Now().AddDate(-2, -2, 0).Format(utils.FormatDate)
- endDate := ""//time.Now().Format(utils.FormatDate)
- err = data_manage.RefreshCalculateBp(edbInfoId, fromEdbInfo, calculateBp.EdbCode, startDate, endDate)
- if err != nil {
- return errors.New("RefreshCalculateTbz Err:" + err.Error())
- }
- }
- } else {
- msg := "刷新失败,无效的指标渠道:source:" + strconv.Itoa(source) + " EdbCode:" + v.EdbCode
- err = errors.New(msg)
- return err
- }
- maxAndMinItem, err := data_manage.GetEdbInfoMaxAndMinInfo(source, edbCode)
- if err != nil {
- return err
- }
- if maxAndMinItem != nil {
- err = data_manage.ModifyEdbInfoMaxAndMinInfo(edbInfoId, maxAndMinItem)
- if err != nil {
- return err
- }
- }
- }
- return err
- }
- //刷新手工指标数据
- func RefreshDataFromManual(wg *sync.WaitGroup) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromManual Err:" + err.Error())
- go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "RefreshDataFromManual ErrMsg:"+err.Error(), utils.EmailSendToUsers)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_MANUAL)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- var endDate string
- endDate = time.Now().AddDate(utils.DATA_END_DATE_LIMIT, 0, 0).Format(utils.FormatDate)
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- err = data_manage.RefreshManual(v.EdbInfoId, v.EdbCode, startDate, endDate)
- if err != nil {
- return errors.New("SyncEdbDataByThs:" + err.Error())
- }
- item, err := data_manage.GetEdbInfoMaxAndMinInfo(v.Source, v.EdbCode)
- if err != nil {
- return err
- }
- if item != nil {
- err = data_manage.ModifyEdbInfoMaxAndMinInfo(v.EdbInfoId, item)
- if err != nil {
- return err
- }
- }
- }
- return err
- }
- //刷新隆众数据
- func RefreshDataFromLz(wg *sync.WaitGroup) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromLz Err:" + err.Error())
- go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "RefreshDataFromLz ErrMsg:"+err.Error(), utils.EmailSendToUsers)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_LZ)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- var endDate string
- endDate = time.Now().AddDate(utils.DATA_END_DATE_LIMIT, 0, 0).Format(utils.FormatDateUnSpace)
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- fmt.Println(startDate, endDate)
- err = data_manage.RefreshEdbDataByLz(v.EdbInfoId, v.EdbCode, startDate, endDate)
- if err != nil {
- return errors.New("RefreshEdbDataByLz:" + err.Error())
- }
- item, err := data_manage.GetEdbInfoMaxAndMinInfo(v.Source, v.EdbCode)
- if err != nil {
- return err
- }
- if item != nil {
- err = data_manage.ModifyEdbInfoMaxAndMinInfo(v.EdbInfoId, item)
- if err != nil {
- return err
- }
- }
- }
- return err
- }
- //刷新有色数据
- func RefreshDataFromYs(wg *sync.WaitGroup) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromYs Err:" + err.Error())
- go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "RefreshDataFromYs ErrMsg:"+err.Error(), utils.EmailSendToUsers)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_YS)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- var endDate string
- endDate = time.Now().AddDate(utils.DATA_END_DATE_LIMIT, 0, 0).Format(utils.FormatDateUnSpace)
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- fmt.Println(startDate, endDate)
- err = data_manage.RefreshEdbDataByYs(v.EdbInfoId, v.EdbCode, startDate, endDate)
- if err != nil {
- return errors.New("RefreshEdbDataByYs:" + err.Error())
- }
- item, err := data_manage.GetEdbInfoMaxAndMinInfo(v.Source, v.EdbCode)
- if err != nil {
- return err
- }
- if item != nil {
- err = data_manage.ModifyEdbInfoMaxAndMinInfo(v.EdbInfoId, item)
- if err != nil {
- return err
- }
- }
- }
- return err
- }
- //刷新钢联数据
- func RefreshDataFromGl(wg *sync.WaitGroup) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromGl Err:" + err.Error())
- go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "RefreshDataFromYs ErrMsg:"+err.Error(), utils.EmailSendToUsers)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_GL)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- var endDate string
- endDate = time.Now().AddDate(utils.DATA_END_DATE_LIMIT, 0, 0).Format(utils.FormatDateUnSpace)
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- fmt.Println(startDate, endDate)
- err = data_manage.RefreshEdbDataByGl(v.EdbInfoId, v.EdbCode, startDate, endDate)
- if err != nil {
- return errors.New("RefreshEdbDataByGl:" + err.Error())
- }
- item, err := data_manage.GetEdbInfoMaxAndMinInfo(v.Source, v.EdbCode)
- if err != nil {
- return err
- }
- if item != nil {
- err = data_manage.ModifyEdbInfoMaxAndMinInfo(v.EdbInfoId, item)
- if err != nil {
- return err
- }
- }
- }
- return err
- }
- func ResetEdbInfoIsUpdate(cont context.Context) (err error) {
- go data_manage.ResetEdbInfoIsUpdate()
- return nil
- }
|