edb_info.go 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341
  1. package models
  2. import (
  3. "eta/eta_forum_admin/utils"
  4. "github.com/beego/beego/v2/client/orm"
  5. "time"
  6. )
  7. type EdbInfo struct {
  8. EdbInfoId int `orm:"column(edb_info_id);pk"`
  9. EdbInfoType int `description:"指标类型,0:普通指标,1:预测指标"`
  10. SourceName string `description:"来源名称"`
  11. Source int `description:"来源id"`
  12. EdbCode string `description:"指标编码"`
  13. EdbName string `description:"指标名称"`
  14. EdbNameEn string `description:"英文指标名称"`
  15. EdbNameSource string `description:"指标名称来源"`
  16. Frequency string `description:"频率"`
  17. Unit string `description:"单位"`
  18. UnitEn string `description:"英文单位"`
  19. StartDate string `description:"起始日期"`
  20. EndDate string `description:"终止日期"`
  21. ClassifyId int `description:"分类id"`
  22. SysUserId int
  23. SysUserRealName string
  24. UniqueCode string `description:"指标唯一编码"`
  25. CreateTime time.Time
  26. ModifyTime time.Time
  27. MinValue float64 `description:"指标最小值"`
  28. MaxValue float64 `description:"指标最大值"`
  29. CalculateFormula string `description:"计算公式"`
  30. EdbType int `description:"指标类型:1:基础指标,2:计算指标"`
  31. Sort int `description:"排序字段"`
  32. LatestDate string `description:"数据最新日期(实际日期)"`
  33. LatestValue float64 `description:"数据最新值(实际值)"`
  34. EndValue float64 `description:"数据的最新值(预测日期的最新值)"`
  35. MoveType int `description:"移动方式:1:领先(默认),2:滞后"`
  36. MoveFrequency string `description:"移动频度"`
  37. NoUpdate int8 `description:"是否停止更新,0:继续更新;1:停止更新"`
  38. ServerUrl string `description:"服务器地址"`
  39. ChartImage string `description:"图表图片"`
  40. Calendar string `description:"公历/农历" orm:"default(公历);"`
  41. DataDateType string `orm:"column(data_date_type);size(255);null;default(交易日)"`
  42. ManualSave int `description:"是否有手动保存过上下限: 0-否; 1-是"`
  43. EmptyType int `description:"空值处理类型(0查找前后35天,1不计算,2前值填充,3后值填充,4等于0)"`
  44. MaxEmptyType int `description:"MAX、MIN公式空值处理类型(1、等于0;2、跳过空值)"`
  45. TerminalCode string `description:"终端编码,用于配置在机器上"`
  46. DataUpdateTime string `description:"最近一次数据发生变化的时间"`
  47. ErDataUpdateDate string `description:"本次更新,数据发生变化的最早日期"`
  48. SourceIndexName string `description:"数据源中的指标名称"`
  49. SubSource int `description:"子数据来源:0:经济数据库,1:日期序列"`
  50. SubSourceName string `description:"子数据来源名称"`
  51. IndicatorCode string `description:"指标代码"`
  52. StockCode string `description:"证券代码"`
  53. Extra string `description:"指标额外配置"`
  54. IsJoinPermission int `description:"是否加入权限管控,0:不加入;1:加入;默认:0"`
  55. }
  56. type EdbInfoFullClassify struct {
  57. *EdbInfo
  58. CorrelationStr string `description:"相关性系数字符串"`
  59. HaveOperaAuth bool `description:"是否有数据权限,默认:false"`
  60. }
  61. func AddEdbInfo(item *EdbInfo) (lastId int64, err error) {
  62. o := orm.NewOrm()
  63. lastId, err = o.Insert(item)
  64. return
  65. }
  66. // 更新指标信息
  67. func (e *EdbInfo) Update(col []string) (err error) {
  68. o := orm.NewOrm()
  69. _, err = o.Update(e, col...)
  70. return
  71. }
  72. type BaseEdbNameItem struct {
  73. EdbInfoId int `description:"指标id"`
  74. EdbInfoType int `description:"指标类型,0:普通指标,1:预测指标"`
  75. SourceName string `description:"来源名称"`
  76. Source int `description:"来源id"`
  77. EdbCode string `description:"指标编码"`
  78. EdbName string `description:"指标名称"`
  79. Frequency string `description:"频率"`
  80. Unit string `description:"单位"`
  81. HaveOperaAuth bool `description:"是否有数据权限,默认:false"`
  82. }
  83. type BaseEdbInfoResp struct {
  84. List []*BaseEdbNameItem
  85. }
  86. // 指标检索数据
  87. type EdbInfoSearch struct {
  88. EdbCode string `description:"指标编码"`
  89. StartDate string `description:"起始日期"`
  90. EndDate string `description:"终止日期"`
  91. EdbName string `description:"指标名称"`
  92. Unit string `description:"单位"`
  93. Frequency string `description:"频率"`
  94. DataList []*EdbInfoSearchData
  95. StockList []*StockInfo `description:"时序数据"`
  96. }
  97. type StockInfo struct {
  98. StockCode string
  99. EdbCode string
  100. DataList []*EdbInfoSearchData
  101. }
  102. type EdbInfoSearchData struct {
  103. DataTime string `description:"数据日期"`
  104. Value float64 `description:"数据"`
  105. }
  106. type BaseIndexInfo struct {
  107. IndexName string `description:"数据日期"`
  108. Unit string `description:"单位"`
  109. Frequency string `description:"频率"`
  110. }
  111. type EdbInfoSearchResp struct {
  112. SearchItem *EdbInfoSearch `description:"指标分类"`
  113. Status int `description:"1:数据已存在于弘则数据库,2:新数据,3:数据已存在于弘则数据库,但是当前账号无权限"`
  114. StockSearchList []*EdbInfoSearch
  115. }
  116. func GetEdbInfoByEdbCode(source int, edbCode string) (item *EdbInfo, err error) {
  117. o := orm.NewOrm()
  118. sql := ` SELECT * FROM edb_info WHERE source=? AND edb_code=? `
  119. err = o.Raw(sql, source, edbCode).QueryRow(&item)
  120. return
  121. }
  122. func GetEdbInfoById(edbInfoId int) (item *EdbInfo, err error) {
  123. o := orm.NewOrm()
  124. sql := ` SELECT * FROM edb_info WHERE edb_info_id=? `
  125. err = o.Raw(sql, edbInfoId).QueryRow(&item)
  126. return
  127. }
  128. // GetEdbInfoByUniqueCode
  129. // @Description: 根据uniqueCode获取指标详情
  130. // @author: Roc
  131. // @datetime 2024-01-18 13:40:01
  132. // @param uniqueCode string
  133. // @return item *EdbInfo
  134. // @return err error
  135. func GetEdbInfoByUniqueCode(uniqueCode string) (item *EdbInfo, err error) {
  136. o := orm.NewOrm()
  137. sql := ` SELECT * FROM edb_info WHERE unique_code=? `
  138. err = o.Raw(sql, uniqueCode).QueryRow(&item)
  139. return
  140. }
  141. // GetEdbInfoByIdList 根据指标id集合 获取 指标列表
  142. func GetEdbInfoByIdList(edbInfoIdList []int) (items []*EdbInfo, err error) {
  143. num := len(edbInfoIdList)
  144. if num <= 0 {
  145. return
  146. }
  147. o := orm.NewOrm()
  148. sql := ` SELECT * FROM edb_info WHERE edb_info_id in (` + utils.GetOrmInReplace(num) + `) `
  149. _, err = o.Raw(sql, edbInfoIdList).QueryRows(&items)
  150. return
  151. }
  152. func DeleteEdbInfo(edbInfoId int) (err error) {
  153. o := orm.NewOrm()
  154. to, err := o.Begin()
  155. if err != nil {
  156. return
  157. }
  158. defer func() {
  159. if err != nil {
  160. _ = to.Rollback()
  161. } else {
  162. _ = to.Commit()
  163. }
  164. }()
  165. // 删除指标信息
  166. sql := ` DELETE FROM edb_info WHERE edb_info_id=? `
  167. _, err = to.Raw(sql, edbInfoId).Exec()
  168. if err != nil {
  169. return
  170. }
  171. // 删除计算指标的关系
  172. sql = ` DELETE FROM edb_info_calculate_mapping WHERE edb_info_id=? `
  173. _, err = to.Raw(sql, edbInfoId).Exec()
  174. return
  175. }
  176. func GetEdbInfoCountByCondition(condition string, pars []interface{}) (count int, err error) {
  177. o := orm.NewOrm()
  178. sql := ` SELECT COUNT(1) AS count FROM edb_info WHERE 1=1 `
  179. if condition != "" {
  180. sql += condition
  181. }
  182. err = o.Raw(sql, pars).QueryRow(&count)
  183. return
  184. }
  185. type EditEdbInfoReq struct {
  186. EdbInfoId int `description:"指标ID"`
  187. EdbName string `description:"指标名称"`
  188. Frequency string `description:"频率"`
  189. Unit string `description:"单位"`
  190. ClassifyId int `description:"分类id"`
  191. CalculateFormula string `description:"计算公式"`
  192. }
  193. type EditEdbEnInfoReq struct {
  194. EdbInfoId int `description:"指标ID"`
  195. EdbNameEn string `description:"英文指标名称"`
  196. UnitEn string `description:"英文单位"`
  197. }
  198. func ModifyEdbInfo(item *EditEdbInfoReq) (err error) {
  199. o := orm.NewOrm()
  200. sql := ` UPDATE edb_info
  201. SET
  202. edb_name =?,
  203. edb_name_source =?,
  204. frequency = ?,
  205. unit = ?,
  206. classify_id = ?,
  207. modify_time = NOW()
  208. WHERE edb_info_id = ?`
  209. _, err = o.Raw(sql, item.EdbName, item.EdbName, item.Frequency, item.Unit, item.ClassifyId, item.EdbInfoId).Exec()
  210. return
  211. }
  212. // ModifyEdbEnInfo 修改指标英文信息
  213. func ModifyEdbEnInfo(item *EditEdbEnInfoReq) (err error) {
  214. o := orm.NewOrm()
  215. sql := ` UPDATE edb_info
  216. SET
  217. edb_name_en =?,
  218. unit_en = ?,
  219. modify_time = NOW()
  220. WHERE edb_info_id = ?`
  221. _, err = o.Raw(sql, item.EdbNameEn, item.UnitEn, item.EdbInfoId).Exec()
  222. return
  223. }
  224. type EdbInfoList struct {
  225. EdbInfoId int `orm:"column(edb_info_id);pk"`
  226. EdbInfoType int `description:"指标类型,0:普通指标,1:预测指标"`
  227. SourceName string `description:"来源名称"`
  228. Source int `description:"来源id"`
  229. EdbCode string `description:"指标编码"`
  230. EdbNameEn string `description:"英文指标名称"`
  231. EdbName string `description:"指标名称"`
  232. Frequency string `description:"频率"`
  233. FrequencyEn string `description:"英文频率"`
  234. Unit string `description:"单位"`
  235. UnitEn string `description:"英文单位"`
  236. StartDate string `description:"起始日期"`
  237. EndDate string `description:"终止日期"`
  238. LatestDate string `description:"数据最新日期(实际日期)"`
  239. LatestValue float64 `description:"数据最新值(实际值)"`
  240. EndValue float64 `description:"数据的最新值(预测日期的最新值)"`
  241. ClassifyId int `description:"分类id"`
  242. UniqueCode string `description:"指标唯一编码"`
  243. SysUserId int `description:"创建人id"`
  244. SysUserRealName string `description:"创建人姓名"`
  245. ModifyTime string `description:"最新修改时间"`
  246. CreateTime string `description:"创建时间"`
  247. EdbNameAlias string `json:"-" description:"指标名称,别名"`
  248. EdbType int `description:"指标类型:1:基础指标,2:计算指标"`
  249. ChartImage string `description:"图表图片"`
  250. RuleType int `description:"预测规则,1:最新,2:固定值"`
  251. FixedValue float64 `description:"固定值"`
  252. DataList []*EdbData `description:"实际指标数据"`
  253. PredictDataList []*EdbData `description:"预测指标数据"`
  254. IsEnEdb bool `description:"是否展示英文标识"`
  255. DataInsertConfig EdbDataInsertConfigItem `description:"指标数据插入配置"`
  256. DataDateType string `description:"数据日期类型,枚举值:交易日、自然日"`
  257. EmptyType int `description:"空值处理类型(0查找前后35天,1不计算,2前值填充,3后值填充,4等于0)"`
  258. MaxEmptyType int `description:"MAX、MIN公式空值处理类型(1、等于0;2、跳过空值)"`
  259. SubSource int `description:"子数据来源:0:经济数据库,1:日期序列"`
  260. SubSourceName string `description:"子数据来源名称"`
  261. IndicatorCode string `description:"指标代码"`
  262. StockCode string `description:"证券代码"`
  263. NoUpdate int8 `description:"是否停止更新,0:继续更新;1:停止更新"`
  264. IsJoinPermission int `description:"是否加入权限管控,0:不加入;1:加入;默认:0"`
  265. HaveOperaAuth bool `description:"是否有数据权限,默认:false"`
  266. }
  267. type EdbDataInsertConfigItem struct {
  268. Date string `description:"插入的日期"`
  269. RealDate string `description:"实际最晚的日期"`
  270. Value string `description:"插入的值"`
  271. }
  272. type EdbData struct {
  273. EdbDataId int `orm:"column(edb_data_id);pk"`
  274. EdbInfoId int
  275. DataTime string
  276. Value float64
  277. }
  278. type EdbInfoListResp struct {
  279. Item *EdbInfoList
  280. }
  281. func GetEdbInfoCalculateMap(edbInfoId, source int) (list []*EdbInfo, err error) {
  282. o := orm.NewOrm()
  283. //calculateTableName := GetEdbInfoCalculateTableName(source)
  284. //sql := ` SELECT b.* FROM %s AS a
  285. // INNER JOIN edb_info AS b ON a.from_edb_info_id=b.edb_info_id
  286. // WHERE a.edb_info_id=? ORDER BY sort ASC `
  287. //sql = fmt.Sprintf(sql, calculateTableName)
  288. sql := ` SELECT b.* FROM edb_info_calculate_mapping AS a
  289. INNER JOIN edb_info AS b ON a.from_edb_info_id=b.edb_info_id
  290. WHERE a.edb_info_id=? ORDER BY sort ASC `
  291. _, err = o.Raw(sql, edbInfoId).QueryRows(&list)
  292. return
  293. }
  294. // TraceEdbInfoResp 指标追溯数据返回
  295. type TraceEdbInfoResp struct {
  296. EdbInfoId int `description:"指标id"`
  297. EdbInfoType int `description:"指标类型: 0-普通指标; 1-预测指标"`
  298. EdbName string `description:"指标名称"`
  299. EdbType int `description:"指标类型: 1-基础指标; 2-计算指标"`
  300. RuleTitle string `description:"指标规则"`
  301. UniqueCode string `description:"唯一编码"`
  302. ClassifyId int `description:"分类ID"`
  303. Child []TraceEdbInfoResp `description:"下级来源"`
  304. IsStop int8 `description:"是否终止"`
  305. EdbInfo *EdbInfo `description:"指标信息" json:"-"`
  306. }