base_from_smm.go 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332
  1. package models
  2. import (
  3. "eta/eta_index_lib/utils"
  4. "fmt"
  5. "strconv"
  6. "strings"
  7. "time"
  8. "github.com/beego/beego/v2/client/orm"
  9. )
  10. type BaseFromSmmData struct {
  11. SmmDataId int `orm:"column(smm_data_id);pk"`
  12. BaseFromSmmIndexId int
  13. IndexCode string
  14. DataTime string
  15. Value string
  16. CreateTime time.Time
  17. ModifyTime time.Time
  18. DataTimestamp int64
  19. }
  20. func AddBaseFromSmmData(item []*BaseFromSmmData) (err error) {
  21. o := orm.NewOrm()
  22. _, err = o.InsertMulti(len(item), item)
  23. return
  24. }
  25. func GetBaseFromSmmDataByCondition(condition string, pars []interface{}) (list []*BaseFromSmmData, err error) {
  26. o := orm.NewOrm()
  27. sql := `SELECT * FROM base_from_smm_data WHERE 1=1 `
  28. if condition != "" {
  29. sql += condition
  30. }
  31. _, err = o.Raw(sql, pars).QueryRows(&list)
  32. return
  33. }
  34. // 新增有色指标数据
  35. func AddEdbDataFromSmm(edbCode string) (err error) {
  36. o := orm.NewOrm()
  37. var condition string
  38. var pars []interface{}
  39. if edbCode != "" {
  40. condition += " AND index_code=? "
  41. pars = append(pars, edbCode)
  42. }
  43. smmBaseDataAll, err := GetBaseFromSmmDataByCondition(condition, pars)
  44. if err != nil && err.Error() != utils.ErrNoRow() {
  45. return
  46. }
  47. var isAdd bool
  48. addSql := ` INSERT INTO edb_data_ys(edb_info_id,edb_code,data_time,value,create_time,modify_time,data_timestamp) values `
  49. existMap := make(map[string]string)
  50. for _, sv := range smmBaseDataAll {
  51. eDate := sv.DataTime
  52. dataTime, err := time.ParseInLocation(utils.FormatDate, eDate, time.Local)
  53. if err != nil {
  54. return err
  55. }
  56. timestamp := dataTime.UnixNano() / 1e6
  57. timeStr := fmt.Sprintf("%d", timestamp)
  58. if _, ok := existMap[eDate]; !ok {
  59. addSql += GetAddSql("0", edbCode, eDate, timeStr, sv.Value)
  60. isAdd = true
  61. }
  62. existMap[eDate] = sv.Value
  63. }
  64. if isAdd {
  65. addSql = strings.TrimRight(addSql, ",")
  66. utils.FileLog.Info("addSql:" + addSql)
  67. _, err = o.Raw(addSql).Exec()
  68. if err != nil {
  69. return err
  70. }
  71. }
  72. return
  73. }
  74. // 刷新有色指标数据
  75. func RefreshEdbDataFromSmm(edbInfoId int, edbCode, startDate string) (err error) {
  76. source := utils.DATA_SOURCE_YS
  77. o := orm.NewOrm()
  78. if err != nil {
  79. return
  80. }
  81. edbInfoIdStr := strconv.Itoa(edbInfoId)
  82. //计算数据
  83. var condition string
  84. var pars []interface{}
  85. if edbCode != "" {
  86. condition += " AND index_code=? "
  87. pars = append(pars, edbCode)
  88. }
  89. if startDate != "" {
  90. condition += " AND data_time>=? "
  91. pars = append(pars, startDate)
  92. }
  93. smmDataList, err := GetBaseFromSmmDataByCondition(condition, pars)
  94. if err != nil {
  95. return
  96. }
  97. // 真实数据的最大日期 , 插入规则配置的日期
  98. var realDataMaxDate, edbDataInsertConfigDate time.Time
  99. var edbDataInsertConfig *EdbDataInsertConfig
  100. var isFindConfigDateRealData bool //是否找到配置日期的实际数据的值
  101. {
  102. edbDataInsertConfig, err = GetEdbDataInsertConfigByEdbId(edbInfoId)
  103. if err != nil && err.Error() != utils.ErrNoRow() {
  104. return
  105. }
  106. if edbDataInsertConfig != nil {
  107. edbDataInsertConfigDate = edbDataInsertConfig.Date
  108. }
  109. }
  110. var existCondition string
  111. var existPars []interface{}
  112. existCondition += " AND edb_info_id=? "
  113. existPars = append(existPars, edbInfoId)
  114. if startDate != "" {
  115. existCondition += " AND data_time>=? "
  116. existPars = append(existPars, startDate)
  117. }
  118. existList, err := GetEdbDataByCondition(source, existCondition, existPars)
  119. if err != nil {
  120. return err
  121. }
  122. existMap := make(map[string]*EdbInfoSearchData)
  123. for _, v := range existList {
  124. existMap[v.DataTime] = v
  125. }
  126. addSql := ` INSERT INTO edb_data_ys(edb_info_id,edb_code,data_time,value,create_time,modify_time,data_timestamp) values `
  127. var isAdd bool
  128. for _, v := range smmDataList {
  129. item := v
  130. eDate := item.DataTime
  131. dataTime, err := time.ParseInLocation(utils.FormatDate, eDate, time.Local)
  132. if err != nil {
  133. return err
  134. }
  135. if findItem, ok := existMap[v.DataTime]; !ok {
  136. sValue := item.Value
  137. timestamp := dataTime.UnixNano() / 1e6
  138. timeStr := fmt.Sprintf("%d", timestamp)
  139. addSql += GetAddSql(edbInfoIdStr, edbCode, eDate, timeStr, sValue)
  140. isAdd = true
  141. } else {
  142. if findItem != nil && utils.SubFloatToString(findItem.Value, 30) != item.Value {
  143. err = ModifyEdbDataById(source, findItem.EdbDataId, item.Value)
  144. if err != nil {
  145. return err
  146. }
  147. }
  148. }
  149. // 下面代码主要目的是处理掉手动插入的数据判断
  150. {
  151. if realDataMaxDate.IsZero() || dataTime.After(realDataMaxDate) {
  152. realDataMaxDate = dataTime
  153. }
  154. if edbDataInsertConfigDate.IsZero() || dataTime.Equal(edbDataInsertConfigDate) {
  155. isFindConfigDateRealData = true
  156. }
  157. }
  158. }
  159. // 处理手工数据补充的配置
  160. HandleConfigInsertEdbData(realDataMaxDate, edbDataInsertConfig, edbInfoId, source, existMap, isFindConfigDateRealData)
  161. if isAdd {
  162. addSql = strings.TrimRight(addSql, ",")
  163. _, err = o.Raw(addSql).Exec()
  164. if err != nil {
  165. fmt.Println("RefreshEdbDataFromSmm add Err", err.Error())
  166. return
  167. }
  168. }
  169. return
  170. }
  171. type BaseFromSmmIndex struct {
  172. BaseFromSmmIndexId int64 `orm:"column(base_from_smm_index_id);pk"`
  173. ClassifyId int
  174. Interface string
  175. Name string
  176. IndexCode string
  177. IndexName string
  178. Type1 string `orm:"column(type_1)"`
  179. Type2 string `orm:"column(type_2)"`
  180. Type3 string `orm:"column(type_3)"`
  181. Frequency string
  182. Unit string
  183. ApiStartTime string
  184. ApiUpdateTime string
  185. StartTime string
  186. FinishTime string
  187. BaseFileName string
  188. RenameFileName string
  189. StartDate string
  190. EndDate string
  191. TerminalCode string `description:"编码"`
  192. CreateTime time.Time
  193. ModifyTime time.Time
  194. }
  195. func (d *BaseFromSmmIndex) AddBaseFromSmmIndex() (lastId int64, err error) {
  196. o := orm.NewOrm()
  197. lastId, err = o.Insert(d)
  198. return
  199. }
  200. func (d *BaseFromSmmIndex) GetSmmIndexItem(indexCode string) (item *BaseFromSmmIndex, err error) {
  201. o := orm.NewOrm()
  202. sql := ` SELECT * FROM base_from_smm_index WHERE index_code=? `
  203. fmt.Println(sql, indexCode)
  204. err = o.Raw(sql, indexCode).QueryRow(&item)
  205. return
  206. }
  207. // Add 新增
  208. func (m *BaseFromSmmIndex) Add() (err error) {
  209. o := orm.NewOrm()
  210. _, err = o.Insert(m)
  211. return
  212. }
  213. func GetBaseFromSmmDataBySmmCode(smmCode string) (list []*BaseFromSmmData, err error) {
  214. o := orm.NewOrm()
  215. sql := ` SELECT * FROM base_from_smm_data WHERE index_code=? `
  216. _, err = o.Raw(sql, smmCode).QueryRows(&list)
  217. return
  218. }
  219. func ModifySmmIndexSort(baseFromSmmIndexId int64) (err error) {
  220. o := orm.NewOrm()
  221. sql := ` UPDATE base_from_smm_index SET sort=? WHERE base_from_smm_index_id=? `
  222. _, err = o.Raw(sql, baseFromSmmIndexId, baseFromSmmIndexId).Exec()
  223. return
  224. }
  225. func GetSmmIndexInfoMaxAndMinInfo(indexCode string) (item *EdbInfoMaxAndMinInfo, err error) {
  226. o := orm.NewOrm()
  227. sql := ` SELECT MIN(data_time) AS min_date,MAX(data_time) AS max_date,MIN(value) AS min_value,MAX(value) AS max_value FROM base_from_smm_data WHERE index_code=? `
  228. err = o.Raw(sql, indexCode).QueryRow(&item)
  229. return
  230. }
  231. func ModifySmmIndexMaxAndMinInfo(indexCode string, item *EdbInfoMaxAndMinInfo) (err error) {
  232. o := orm.NewOrm()
  233. sql := ` UPDATE base_from_smm_index SET start_date=?,end_date=?,modify_time=NOW() WHERE index_code=? `
  234. _, err = o.Raw(sql, item.MinDate, item.MaxDate, indexCode).Exec()
  235. return
  236. }
  237. // HandleSmmExcelDataReq SMM的excel数据
  238. type HandleSmmExcelDataReq struct {
  239. BaseFilePath string
  240. RenameFilePath string
  241. IndexName string
  242. Source string
  243. IndexCode string
  244. Unit string
  245. Frequency string
  246. ExcelDataMap map[string]string
  247. TerminalCode string `description:"编码"`
  248. }
  249. // MultiUpdateBaseFromSmmDataValue 批量更新SMM指标数据
  250. func MultiUpdateBaseFromSmmDataValue(items []*BaseFromSmmData) (err error) {
  251. if len(items) == 0 {
  252. return
  253. }
  254. o := orm.NewOrm()
  255. sql := `UPDATE base_from_smm_data SET value = ?, modify_time = NOW() WHERE index_code = ? AND data_time = ? LIMIT 1`
  256. p, err := o.Raw(sql).Prepare()
  257. if err != nil {
  258. return
  259. }
  260. defer func() {
  261. _ = p.Close()
  262. }()
  263. for _, v := range items {
  264. if v.IndexCode == "" || v.DataTime == "" {
  265. continue
  266. }
  267. _, err = p.Exec(v.Value, v.IndexCode, v.DataTime)
  268. if err != nil {
  269. return
  270. }
  271. }
  272. return
  273. }
  274. type AddSmmIndexToDataSourceResp struct {
  275. EdbCode string `description:"指标编码"`
  276. ClassifyId int `description:"指标分类"`
  277. SysUserId int `description:"操作人id"`
  278. SysUserRealName string `description:"操作人真实名称"`
  279. }
  280. func (m *BaseFromSmmIndex) GetIndexItem(indexCode string) (item *BaseFromSmmIndex, err error) {
  281. o := orm.NewOrm()
  282. sql := `SELECT * FROM base_from_smm_index WHERE index_code = ? `
  283. err = o.Raw(sql, indexCode).QueryRow(&item)
  284. return
  285. }
  286. // 修改
  287. func (m *BaseFromSmmIndex) Update(updateParams, whereParam map[string]interface{}) (err error) {
  288. to := orm.NewOrm()
  289. ptrStructOrTableName := "base_from_smm_index"
  290. qs := to.QueryTable(ptrStructOrTableName)
  291. for expr, exprV := range whereParam {
  292. qs = qs.Filter(expr, exprV)
  293. }
  294. _, err = qs.Update(updateParams)
  295. return
  296. }