123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755 |
- package data
- import (
- "errors"
- "fmt"
- "hongze/hongze_chart_lib/models/data_manage"
- "hongze/hongze_chart_lib/utils"
- "sort"
- "strconv"
- "time"
- )
- func ChartInfoRefresh(chartInfoId int) (err error) {
- var errmsg string
- defer func() {
- if err != nil {
- go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "ChartInfoRefresh:"+errmsg, utils.EmailSendToUsers)
- fmt.Println("ChartInfoRefresh Err:" + errmsg)
- }
- }()
- baseEdbInfoArr, calculateInfoArr, err := data_manage.GetChartInfoRefreshData(chartInfoId)
- if err != nil {
- errmsg = "获取需要刷新的指标失败:Err:" + err.Error()
- return
- }
- var startDate string
- newBaseEdbInfoArr := make([]*data_manage.EdbInfo, 0)
- baseMap := make(map[int]*data_manage.EdbInfo)
- for _, bv := range baseEdbInfoArr {
- if _, ok := baseMap[bv.EdbInfoId]; !ok {
- newBaseEdbInfoArr = append(newBaseEdbInfoArr, bv)
- }
- baseMap[bv.EdbInfoId] = bv
- }
- fmt.Println("calculateInfoArr:", len(calculateInfoArr))
- newCalculateInfoArr := make([]*data_manage.EdbInfo, 0)
- calculateMap := make(map[int]*data_manage.EdbInfo)
- var calculateArr []int
- for _, bv := range calculateInfoArr {
- if _, ok := calculateMap[bv.EdbInfoId]; !ok {
- newCalculateInfoArr = append(newCalculateInfoArr, bv)
- calculateArr = append(calculateArr, bv.EdbInfoId)
- }
- calculateMap[bv.EdbInfoId] = bv
- }
- sort.Ints(calculateArr)
- for _, bv := range newBaseEdbInfoArr {
- source := bv.Source
- edbInfoId := bv.EdbInfoId
- edbCode := bv.EdbCode
- startDate = bv.StartDate
- sTime, err := time.Parse(utils.FormatDate, bv.EndDate)
- if err != nil {
- return err
- }
- startDate = sTime.Format(utils.FormatDate)
- if source == utils.DATA_SOURCE_THS {
- endDate := time.Now().AddDate(utils.DATA_END_DATE_LIMIT, 0, 0).Format(utils.FormatDate)
- err = RefreshEdbDataByThs(edbInfoId, edbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshEdbDataByThs Err:" + err.Error()
- }
- } else if source == utils.DATA_SOURCE_WIND {
- endDate := time.Now().Format(utils.FormatDate)
- err = RefreshEdbDataByWind(edbInfoId, edbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshEdbDataByWind Err:" + err.Error()
- }
- } else if source == utils.DATA_SOURCE_PB {
- startDate := sTime.Format(utils.FormatDateUnSpace)
- endDate := time.Now().AddDate(utils.DATA_END_DATE_LIMIT, 0, 0).Format(utils.FormatDateUnSpace)
- err = RefreshEdbDataByPb(edbInfoId, edbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshEdbDataByPb Err:" + err.Error()
- }
- } else if source == utils.DATA_SOURCE_MANUAL {
- endDate := time.Now().AddDate(utils.DATA_END_DATE_LIMIT, 0, 0).Format(utils.FormatDate)
- err = data_manage.RefreshEdbDataByManual(edbInfoId, edbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshEdbDataByManual Err:" + err.Error()
- }
- } else if source == utils.DATA_SOURCE_LZ {
- endDate := time.Now().AddDate(utils.DATA_END_DATE_LIMIT, 0, 0).Format(utils.FormatDate)
- err = data_manage.RefreshEdbDataByLz(edbInfoId, edbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshEdbDataByLz Err:" + err.Error()
- }
- } else if source == utils.DATA_SOURCE_YS {
- endDate := time.Now().AddDate(utils.DATA_END_DATE_LIMIT, 0, 0).Format(utils.FormatDate)
- err = data_manage.RefreshAllEdbDataByYs(edbInfoId, source, edbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshEdbDataByYs Err:" + err.Error()
- }
- } else if source == utils.DATA_SOURCE_GL {
- endDate := time.Now().AddDate(utils.DATA_END_DATE_LIMIT, 0, 0).Format(utils.FormatDate)
- err = data_manage.RefreshEdbDataByGl(edbInfoId, edbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshEdbDataByGl Err:" + err.Error()
- }
- }else if source == utils.DATA_SOURCE_LT {
- endDate := time.Now().Format(utils.FormatDate)
- err = data_manage.RefreshAllEdbDataByLt(edbInfoId, source, edbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshAllEdbDataByLT Err:" + err.Error()
- }
- }else if source == utils.DATA_SOURCE_COAL {
- endDate := time.Now().Format(utils.FormatDate)
- err = data_manage.RefreshEdbDataByCoal(edbInfoId, edbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshEdbDataByGl Err:" + err.Error()
- }
- }
- 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
- }
- }
- }
- for _, v := range calculateArr {
- edbInfo := calculateMap[v]
- if edbInfo == nil {
- return err
- }
- edbInfoId := edbInfo.EdbInfoId
- source := edbInfo.Source
- edbCode := edbInfo.EdbCode
- fmt.Println("source:", source)
- fmt.Println("edbInfoId:", edbInfoId)
- if source == utils.DATA_SOURCE_CALCULATE { //指标运算
- startDate = edbInfo.StartDate
- sTime, err := time.Parse(utils.FormatDate, edbInfo.EndDate)
- if err != nil {
- return err
- }
- startDate = sTime.Format(utils.FormatDate)
- var edbInfoIdBytes []string
- calculateMap, err := data_manage.GetEdbInfoCalculateDetail(edbInfoId, edbInfo.Source)
- if err != nil {
- errmsg = "GetEdbInfoCalculateDetail Err:" + err.Error()
- return err
- }
- 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)
- }
- fmt.Println("start RefreshCalculate")
- endDate := ""
- err = RefreshCalculate(edbInfoList, int(edbInfoId), edbInfo.EdbCode, edbInfo.CalculateFormula, startDate, endDate, edbInfoIdBytes)
- if err != nil {
- errmsg = "RefreshCalculate Err:" + err.Error()
- return err
- }
- } else if source == utils.DATA_SOURCE_CALCULATE_LJZZY { //刷新累计值转月值
- calculateLjzzy, err := data_manage.GetEdbInfoCalculateLjzzyDetail(edbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoCalculateLjzzyDetail Err:" + err.Error()
- return err
- }
- fromEdbInfo, err := data_manage.GetEdbInfoById(calculateLjzzy.FromEdbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoById Err:" + err.Error()
- return err
- }
- year := time.Now().Year()
- startDate = strconv.Itoa(year) + "-01" + "-01"
- endDate := ""
- err = data_manage.RefreshCalculateLjzzy(edbInfoId, fromEdbInfo, calculateLjzzy.EdbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshCalculateLjzzy Err:" + err.Error()
- return err
- }
- } else if source == utils.DATA_SOURCE_CALCULATE_TBZ { //刷新同比值
- calculateTbz, err := data_manage.GetEdbInfoCalculateTbzDetail(edbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoCalculateTbzDetail Err:" + err.Error()
- return err
- }
- fromEdbInfo, err := data_manage.GetEdbInfoById(calculateTbz.FromEdbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoById Err:" + err.Error()
- return err
- }
- startDate = time.Now().AddDate(-1, -2, 0).Format(utils.FormatDate)
- endDate := "" // time.Now().Format(utils.FormatDate)
- err = data_manage.RefreshCalculateTbz(edbInfoId, fromEdbInfo, calculateTbz.EdbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshCalculateTbz Err:" + err.Error()
- return err
- }
- } else if source == utils.DATA_SOURCE_CALCULATE_TCZ { //同差值
- calculateTcz, err := data_manage.GetEdbInfoCalculateTczDetail(edbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoCalculateTczDetail Err:" + err.Error()
- return err
- }
- fromEdbInfo, err := data_manage.GetEdbInfoById(calculateTcz.FromEdbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoById Err:" + err.Error()
- return err
- }
- startDate = time.Now().AddDate(-1, -2, 0).Format(utils.FormatDate)
- endDate := "" //time.Now().Format(utils.FormatDate)
- err = data_manage.RefreshCalculateTcz(edbInfoId, fromEdbInfo, calculateTcz.EdbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshCalculateTcz Err:" + err.Error()
- return err
- }
- } else if source == utils.DATA_SOURCE_CALCULATE_NSZYDPJJS { //N数值移动平均计算
- fmt.Println("刷新计算指标:", edbInfoId)
- calculateNszydpjjs, err := data_manage.GetEdbInfoCalculateNszydpjjsDetail(edbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoCalculateNszydpjjsDetail Err:" + err.Error()
- return err
- }
- fromEdbInfo, err := data_manage.GetEdbInfoById(calculateNszydpjjs.FromEdbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoById Err:" + err.Error()
- return err
- }
- formulaInt, _ := strconv.Atoi(edbInfo.CalculateFormula)
- err = data_manage.RefreshCalculateNszydpjjs(edbInfoId, edbInfo.Source, formulaInt, fromEdbInfo, calculateNszydpjjs.EdbCode)
- if err != nil {
- errmsg = "RefreshCalculateNszydpjjs Err:" + err.Error()
- return err
- }
- } else if source == utils.DATA_SOURCE_CALCULATE_HBZ { //刷新环比
- calculateTbz, err := data_manage.GetEdbInfoCalculateHbzDetail(edbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoCalculateHbzDetail Err:" + err.Error()
- return err
- }
- fromEdbInfo, err := data_manage.GetEdbInfoById(calculateTbz.FromEdbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoById Err:" + err.Error()
- return err
- }
- startDate = time.Now().AddDate(-1, -2, 0).Format(utils.FormatDate)
- endDate := "" //time.Now().Format(utils.FormatDate)
- err = data_manage.RefreshCalculateHbz(edbInfoId, edbInfo.Source, fromEdbInfo, calculateTbz.EdbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshCalculateHbz Err:" + err.Error()
- return err
- }
- } else if source == utils.DATA_SOURCE_CALCULATE_HCZ { //刷新环差值
- calculateTbz, err := data_manage.GetEdbInfoCalculateHczDetail(edbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoCalculateHczDetail Err:" + err.Error()
- return err
- }
- fromEdbInfo, err := data_manage.GetEdbInfoById(calculateTbz.FromEdbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoById Err:" + err.Error()
- return err
- }
- startDate = time.Now().AddDate(-1, -2, 0).Format(utils.FormatDate)
- endDate := "" //time.Now().Format(utils.FormatDate)
- err = data_manage.RefreshCalculateHcz(edbInfoId, edbInfo.Source, fromEdbInfo, calculateTbz.EdbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshCalculateHcz Err:" + err.Error()
- return err
- }
- } else if source == utils.DATA_SOURCE_CALCULATE_BP { //刷新变频
- calculateTbz, err := data_manage.GetEdbInfoCalculateBpDetail(edbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoCalculateBpDetail Err:" + err.Error()
- return err
- }
- fromEdbInfo, err := data_manage.GetEdbInfoById(calculateTbz.FromEdbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoById Err:" + err.Error()
- return err
- }
- startDate = time.Now().AddDate(-1, -2, 0).Format(utils.FormatDate)
- endDate := "" //time.Now().Format(utils.FormatDate)
- err = data_manage.RefreshCalculateBp(edbInfoId, fromEdbInfo, calculateTbz.EdbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshCalculateBp Err:" + err.Error()
- 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
- }
- // ChartInfoRefreshVOld 图表刷新(旧版,2022年03月25日11:35:06 作废)
- func ChartInfoRefreshVOld(chartInfoId int) (err error) {
- var errmsg string
- defer func() {
- if err != nil {
- go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "ChartInfoRefresh:"+errmsg, utils.EmailSendToUsers)
- fmt.Println("ChartInfoRefresh Err:" + errmsg)
- }
- }()
- baseEdbInfoArr, calculateInfoArr, err := data_manage.GetChartInfoRefreshData(chartInfoId)
- if err != nil {
- errmsg = "获取需要刷新的指标失败:Err:" + err.Error()
- return
- }
- var startDate string
- newBaseEdbInfoArr := make([]*data_manage.EdbInfo, 0)
- baseMap := make(map[int]*data_manage.EdbInfo)
- for _, bv := range baseEdbInfoArr {
- if _, ok := baseMap[bv.EdbInfoId]; !ok {
- newBaseEdbInfoArr = append(newBaseEdbInfoArr, bv)
- }
- baseMap[bv.EdbInfoId] = bv
- }
- fmt.Println("calculateInfoArr:", len(calculateInfoArr))
- newCalculateInfoArr := make([]*data_manage.EdbInfo, 0)
- calculateMap := make(map[int]*data_manage.EdbInfo)
- var calculateArr []int
- for _, bv := range calculateInfoArr {
- if _, ok := calculateMap[bv.EdbInfoId]; !ok {
- newCalculateInfoArr = append(newCalculateInfoArr, bv)
- calculateArr = append(calculateArr, bv.EdbInfoId)
- }
- calculateMap[bv.EdbInfoId] = bv
- }
- sort.Ints(calculateArr)
- for _, bv := range newBaseEdbInfoArr {
- source := bv.Source
- edbInfoId := bv.EdbInfoId
- edbCode := bv.EdbCode
- startDate = bv.StartDate
- sTime, err := time.Parse(utils.FormatDate, bv.EndDate)
- if err != nil {
- return err
- }
- startDate = sTime.Format(utils.FormatDate)
- if source == utils.DATA_SOURCE_THS {
- endDate := time.Now().AddDate(utils.DATA_END_DATE_LIMIT, 0, 0).Format(utils.FormatDate)
- err = RefreshEdbDataByThs(edbInfoId, edbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshEdbDataByThs Err:" + err.Error()
- }
- } else if source == utils.DATA_SOURCE_WIND {
- endDate := time.Now().Format(utils.FormatDate)
- err = RefreshEdbDataByWind(edbInfoId, edbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshEdbDataByWind Err:" + err.Error()
- }
- } else if source == utils.DATA_SOURCE_PB {
- startDate := sTime.Format(utils.FormatDateUnSpace)
- endDate := time.Now().AddDate(utils.DATA_END_DATE_LIMIT, 0, 0).Format(utils.FormatDateUnSpace)
- err = RefreshEdbDataByPb(edbInfoId, edbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshEdbDataByPb Err:" + err.Error()
- }
- } else if source == utils.DATA_SOURCE_MANUAL {
- err = data_manage.RefreshAllEdbDataByManual(edbInfoId,bv.Source, edbCode)
- if err != nil {
- errmsg = "RefreshEdbDataByManual Err:" + err.Error()
- }
- } else if source == utils.DATA_SOURCE_LZ {
- endDate := time.Now().AddDate(utils.DATA_END_DATE_LIMIT, 0, 0).Format(utils.FormatDate)
- err = data_manage.RefreshEdbDataByLz(edbInfoId, edbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshEdbDataByLz Err:" + err.Error()
- }
- } else if source == utils.DATA_SOURCE_YS {
- endDate := time.Now().AddDate(utils.DATA_END_DATE_LIMIT, 0, 0).Format(utils.FormatDate)
- err = data_manage.RefreshAllEdbDataByYs(edbInfoId, source, edbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshEdbDataByYs Err:" + err.Error()
- }
- } else if source == utils.DATA_SOURCE_GL {
- endDate := time.Now().AddDate(utils.DATA_END_DATE_LIMIT, 0, 0).Format(utils.FormatDate)
- err = data_manage.RefreshEdbDataByGl(edbInfoId, edbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshEdbDataByGl Err:" + err.Error()
- }
- }else if source == utils.DATA_SOURCE_LT {
- endDate := time.Now().Format(utils.FormatDate)
- err = data_manage.RefreshAllEdbDataByLt(edbInfoId, source, edbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshAllEdbDataByLT Err:" + err.Error()
- }
- }else if source == utils.DATA_SOURCE_COAL {
- endDate := time.Now().Format(utils.FormatDate)
- err = data_manage.RefreshAllEdbDataByCoal(edbInfoId, source, edbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshAllEdbDataByCoal Err:" + err.Error()
- }
- }
- 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
- }
- }
- }
- endDate := "" //计算指标不限制日期
- //刷新相关计算指标
- for _, v := range calculateArr {
- edbInfo := calculateMap[v]
- if edbInfo == nil {
- return err
- }
- edbInfoId := edbInfo.EdbInfoId
- source := edbInfo.Source
- edbCode := edbInfo.EdbCode
- if source == utils.DATA_SOURCE_CALCULATE {
- startDate = edbInfo.StartDate
- sTime, err := time.Parse(utils.FormatDate, edbInfo.EndDate)
- if err != nil {
- return err
- }
- startDate = sTime.Format(utils.FormatDate)
- var edbInfoIdBytes []string
- calculateMap, err := data_manage.GetEdbInfoCalculateDetail(edbInfoId, edbInfo.Source)
- if err != nil {
- errmsg = "GetEdbInfoCalculateDetail Err:" + err.Error()
- return err
- }
- 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)
- }
- err = data_manage.RefreshAllCalculate(edbInfoList, int(edbInfoId), source, edbInfo.EdbCode, edbInfo.CalculateFormula, startDate, endDate, edbInfoIdBytes)
- if err != nil {
- errmsg = "RefreshCalculate Err:" + err.Error()
- return err
- }
- } else if source == utils.DATA_SOURCE_CALCULATE_LJZZY { //刷新累计值转月值
- calculateLjzzy, err := data_manage.GetEdbInfoCalculateLjzzyDetail(edbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoCalculateLjzzyDetail Err:" + err.Error()
- return err
- }
- fromEdbInfo, err := data_manage.GetEdbInfoById(calculateLjzzy.FromEdbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoById Err:" + err.Error()
- return err
- }
- startDate = edbInfo.StartDate
- endDate = time.Now().Format(utils.FormatDate)
- err = data_manage.RefreshAllCalculateLjzzy(edbInfoId, source, fromEdbInfo, calculateLjzzy.EdbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshAllCalculateLjzzy Err:" + err.Error()
- return err
- }
- } else if source == utils.DATA_SOURCE_CALCULATE_TBZ { //刷新同比值
- calculateTbz, err := data_manage.GetEdbInfoCalculateTbzDetail(edbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoCalculateTbzDetail Err:" + err.Error()
- return err
- }
- fromEdbInfo, err := data_manage.GetEdbInfoById(calculateTbz.FromEdbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoById Err:" + err.Error()
- return err
- }
- startDate = edbInfo.StartDate
- endDate = time.Now().Format(utils.FormatDate)
- err = data_manage.RefreshAllCalculateTbz(edbInfoId, source, fromEdbInfo, calculateTbz.EdbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshAllCalculateTbz Err:" + err.Error()
- return err
- }
- } else if source == utils.DATA_SOURCE_CALCULATE_TCZ { //同差值
- calculateTcz, err := data_manage.GetEdbInfoCalculateTczDetail(edbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoCalculateTczDetail Err:" + err.Error()
- return err
- }
- fromEdbInfo, err := data_manage.GetEdbInfoById(calculateTcz.FromEdbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoById Err:" + err.Error()
- return err
- }
- startDate = edbInfo.StartDate
- endDate = time.Now().Format(utils.FormatDate)
- err = data_manage.RefreshAllCalculateTcz(edbInfoId, source, fromEdbInfo, calculateTcz.EdbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshCalculateTcz Err:" + err.Error()
- return err
- }
- } else if source == utils.DATA_SOURCE_CALCULATE_NSZYDPJJS { //N数值移动平均计算
- calculateNszydpjjs, err := data_manage.GetEdbInfoCalculateNszydpjjsDetail(edbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoCalculateNszydpjjsDetail Err:" + err.Error()
- return err
- }
- fromEdbInfo, err := data_manage.GetEdbInfoById(calculateNszydpjjs.FromEdbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoById Err:" + err.Error()
- return err
- }
- formulaInt, _ := strconv.Atoi(edbInfo.CalculateFormula)
- startDate = edbInfo.StartDate
- err = data_manage.RefreshAllCalculateNszydpjjs(edbInfoId, edbInfo.Source, formulaInt, fromEdbInfo, calculateNszydpjjs.EdbCode, startDate)
- if err != nil {
- errmsg = "RefreshCalculateNszydpjjs Err:" + err.Error()
- return err
- }
- } else if source == utils.DATA_SOURCE_CALCULATE_HBZ { //刷新环比值
- calculateTbz, err := data_manage.GetEdbInfoCalculateHbzDetail(edbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoCalculateHbzDetail Err:" + err.Error()
- return err
- }
- fromEdbInfo, err := data_manage.GetEdbInfoById(calculateTbz.FromEdbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoById Err:" + err.Error()
- return err
- }
- startDate = edbInfo.StartDate
- endDate = time.Now().Format(utils.FormatDate)
- formulaInt, _ := strconv.Atoi(edbInfo.CalculateFormula)
- err = data_manage.RefreshAllCalculateHbz(edbInfoId, source, fromEdbInfo, calculateTbz.EdbCode, startDate, endDate, formulaInt)
- if err != nil {
- errmsg = "RefreshAllCalculateHbz Err:" + err.Error()
- return err
- }
- } else if source == utils.DATA_SOURCE_CALCULATE_HCZ { //刷新环差值
- calculateTbz, err := data_manage.GetEdbInfoCalculateHczDetail(edbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoCalculateHczDetail Err:" + err.Error()
- return err
- }
- fromEdbInfo, err := data_manage.GetEdbInfoById(calculateTbz.FromEdbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoById Err:" + err.Error()
- return err
- }
- startDate = edbInfo.StartDate
- endDate = time.Now().Format(utils.FormatDate)
- formulaInt, _ := strconv.Atoi(edbInfo.CalculateFormula)
- err = data_manage.RefreshAllCalculateHcz(edbInfoId, source, fromEdbInfo, calculateTbz.EdbCode, startDate, endDate, formulaInt)
- if err != nil {
- errmsg = "RefreshAllCalculateHcz Err:" + err.Error()
- return err
- }
- } else if source == utils.DATA_SOURCE_CALCULATE_BP { //刷新变频
- calculateTbz, err := data_manage.GetEdbInfoCalculateBpDetail(edbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoCalculateTbzDetail Err:" + err.Error()
- return err
- }
- fromEdbInfo, err := data_manage.GetEdbInfoById(calculateTbz.FromEdbInfoId)
- if err != nil {
- errmsg = "GetEdbInfoById Err:" + err.Error()
- return err
- }
- startDate = edbInfo.StartDate
- endDate = time.Now().Format(utils.FormatDate)
- err = data_manage.RefreshAllCalculateBp(edbInfoId, source, fromEdbInfo, calculateTbz.EdbCode, startDate, endDate)
- if err != nil {
- errmsg = "RefreshAllCalculateBp Err:" + err.Error()
- return err
- }
- } else if source == utils.DATA_SOURCE_CALCULATE_ZJPJ { //刷新直接拼接数据
- err = data_manage.RefreshAllCalculateZjpj(edbInfo)
- if err != nil {
- errmsg = "RefreshAllCalculateZjpj Err:" + err.Error()
- return err
- }
- } else if source == utils.DATA_SOURCE_CALCULATE_LJZTBPJ { //刷新累计值同比拼接数据
- err = data_manage.RefreshAllCalculateLjztbpj(edbInfo)
- if err != nil {
- errmsg = "RefreshAllCalculateLjztbpj Err:" + err.Error()
- 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
- }
- }
- fmt.Println("end calculateArr:", v, time.Now())
- }
- return err
- }
- // ChartInfoRefreshV1 图表刷新
- func ChartInfoRefreshV1(chartInfoId int) (err error) {
- var errmsg string
- defer func() {
- if err != nil {
- go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "ChartInfoRefresh:"+errmsg, utils.EmailSendToUsers)
- fmt.Println("ChartInfoRefresh Err:" + errmsg)
- }
- }()
- baseEdbInfoArr, calculateInfoArr, err := data_manage.GetChartInfoRefreshData(chartInfoId)
- if err != nil {
- errmsg = "获取需要刷新的指标失败:Err:" + err.Error()
- return
- }
- var startDate string
- newBaseEdbInfoArr := make([]*data_manage.EdbInfo, 0)
- baseMap := make(map[int]*data_manage.EdbInfo)
- for _, bv := range baseEdbInfoArr {
- if _, ok := baseMap[bv.EdbInfoId]; !ok {
- newBaseEdbInfoArr = append(newBaseEdbInfoArr, bv)
- }
- baseMap[bv.EdbInfoId] = bv
- }
- fmt.Println("calculateInfoArr:", len(calculateInfoArr))
- newCalculateInfoArr := make([]*data_manage.EdbInfo, 0)
- calculateMap := make(map[int]*data_manage.EdbInfo)
- var calculateArr []int
- for _, bv := range calculateInfoArr {
- if _, ok := calculateMap[bv.EdbInfoId]; !ok {
- newCalculateInfoArr = append(newCalculateInfoArr, bv)
- calculateArr = append(calculateArr, bv.EdbInfoId)
- }
- calculateMap[bv.EdbInfoId] = bv
- }
- sort.Ints(calculateArr)
- for _, bv := range newBaseEdbInfoArr {
- source := bv.Source
- edbInfoId := bv.EdbInfoId
- edbCode := bv.EdbCode
- startDate = bv.StartDate
- frequency := bv.Frequency
- if bv.StartDate == "0000-00-00" {
- continue
- }
- sTime, err := time.Parse(utils.FormatDate, bv.EndDate)
- if err != nil {
- return err
- }
- var limitDay int
- startDate := ""
- switch frequency {
- case "日度":
- limitDay = utils.DATA_REFRESH
- case "周度":
- limitDay = utils.DATA_REFRESH * 7
- case "月度":
- limitDay = utils.DATA_REFRESH * 30
- case "季度":
- limitDay = utils.DATA_REFRESH * 90
- case "年度":
- limitDay = utils.DATA_REFRESH * 365
- default:
- limitDay = utils.DATA_REFRESH
- }
- startDate = sTime.AddDate(0, 0, -limitDay).Format(utils.FormatDate)
- fmt.Println("source:", source)
- respItem, err := RefreshEdbData(edbInfoId, source, edbCode, startDate)
- if err != nil {
- errmsg = errors.New("RefreshEdbData Err:" + err.Error()).Error()
- return err
- }
- if respItem.Ret != 200 {
- errmsg = errors.New(respItem.ErrMsg + ";EdbCode:" + edbCode).Error()
- 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
- }
- }
- }
- //刷新相关计算指标
- for _, v := range calculateArr {
- edbInfo := calculateMap[v]
- if edbInfo == nil {
- return err
- }
- startDate = edbInfo.StartDate
- source := edbInfo.Source
- if source == utils.DATA_SOURCE_CALCULATE {
- startDate = edbInfo.StartDate
- sTime, err := time.Parse(utils.FormatDate, edbInfo.EndDate)
- if err != nil {
- return err
- }
- startDate = sTime.Format(utils.FormatDate)
- }
- result, err := RefreshEdbCalculateData(edbInfo.EdbInfoId, edbInfo.EdbCode, startDate)
- if err != nil {
- fmt.Println(v, "RefreshEdbCalculateData err", time.Now())
- errmsg = "RefreshEdbCalculateData Err:" + err.Error()
- return err
- }
- if result.Ret != 200 {
- fmt.Println(v, "RefreshEdbCalculateData err;msg:", result.Msg, ";errMsg:", result.ErrMsg)
- errmsg = fmt.Sprint(v, "RefreshEdbCalculateData err;msg:", result.Msg, ";errMsg:", result.ErrMsg)
- return fmt.Errorf("刷新失败"+errmsg)
- }
- fmt.Println("end calculateArr:", v, time.Now())
- }
- return err
- }
|