edb_source_stat.go 28 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061
  1. package data_stat
  2. import (
  3. "encoding/json"
  4. "eta/eta_api/controllers"
  5. "eta/eta_api/models"
  6. "eta/eta_api/models/data_manage"
  7. "eta/eta_api/models/data_stat"
  8. "eta/eta_api/utils"
  9. "fmt"
  10. "github.com/rdlucklib/rdluck_tools/paging"
  11. "strings"
  12. "time"
  13. )
  14. // EdbSourceStatController 数据源统计表管理模块
  15. type EdbSourceStatController struct {
  16. controllers.BaseAuthController
  17. }
  18. // Column
  19. // @Title 数据源统计表自定义列列表
  20. // @Description 查询 数据源统计表自定义列列表
  21. // @Success 200 {object} data_stat.StatColumnList
  22. // @router /source_column [get]
  23. func (this *EdbSourceStatController) Column() {
  24. br := new(models.BaseResponse).Init()
  25. defer func() {
  26. this.Data["json"] = br
  27. this.ServeJSON()
  28. }()
  29. sysUser := this.SysUser
  30. if sysUser == nil {
  31. br.Msg = "请登录"
  32. br.ErrMsg = "请登录,SysUser Is Empty"
  33. br.Ret = 408
  34. return
  35. }
  36. columnType, _ := this.GetInt("ColumnType")
  37. if columnType <= 0 {
  38. br.Msg = "请选择表类型"
  39. return
  40. }
  41. isApi, _ := this.GetInt("IsApi", 0)
  42. tmpList, err := data_stat.GetStatColumn(columnType)
  43. if err != nil {
  44. br.Msg = "获取自定义列失败"
  45. br.ErrMsg = "获取自定义列失败,Err:" + err.Error()
  46. return
  47. }
  48. var list []*data_stat.EdbInfoStatColumnListItem
  49. for _, v := range tmpList {
  50. if isApi == 1 && v.ColumnKey == "InitSourceName" {
  51. continue
  52. }
  53. tmp := new(data_stat.EdbInfoStatColumnListItem)
  54. tmp.ColumnKey = v.ColumnKey
  55. tmp.IsShow = v.IsShow
  56. tmp.ColumnName = v.ColumnName
  57. tmp.ColumnNameEn = v.ColumnNameEn
  58. tmp.Id = v.Id
  59. tmp.IsMust = v.IsMust
  60. tmp.IsSort = v.IsSort
  61. tmp.Type = v.Type
  62. list = append(list, tmp)
  63. }
  64. var statColumnList data_stat.StatColumnList
  65. statColumnList.List = list
  66. br.Ret = 200
  67. br.Success = true
  68. br.Msg = "获取成功"
  69. br.Data = statColumnList
  70. }
  71. // EditColumn
  72. // @Title 编辑数据源统计表自定义列
  73. // @Description 编辑 数据源统计表自定义列列表
  74. // @Success 200 {object} data_stat.StatColumnList
  75. // @router /source_column/edit [post]
  76. func (this *EdbSourceStatController) EditColumn() {
  77. br := new(models.BaseResponse).Init()
  78. defer func() {
  79. this.Data["json"] = br
  80. this.ServeJSON()
  81. }()
  82. sysUser := this.SysUser
  83. if sysUser == nil {
  84. br.Msg = "请登录"
  85. br.ErrMsg = "请登录,SysUser Is Empty"
  86. br.Ret = 408
  87. return
  88. }
  89. var req data_stat.EditStatColumnReq
  90. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  91. if err != nil {
  92. br.Msg = "参数解析异常!"
  93. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  94. return
  95. }
  96. if len(req.List) <= 0 {
  97. br.Msg = "请选择要修改的列"
  98. br.IsSendEmail = false
  99. return
  100. }
  101. tmpList, err := data_stat.GetAllStatColumn()
  102. if err != nil {
  103. br.Msg = "获取自定义列失败"
  104. br.ErrMsg = "获取自定义列失败,Err:" + err.Error()
  105. return
  106. }
  107. isMustMap := make(map[int]data_stat.EdbInfoStatColumn)
  108. if len(tmpList) > 0 {
  109. for _, v := range tmpList {
  110. if v.IsMust == 1 {
  111. isMustMap[v.Id] = v
  112. }
  113. }
  114. }
  115. var list []*data_stat.EdbInfoStatColumn
  116. for k, v := range req.List {
  117. if v.Id == 0 {
  118. br.Msg = "列序号不能为空"
  119. return
  120. }
  121. if v.IsShow == 0 {
  122. if exist, ok := isMustMap[v.Id]; ok {
  123. br.Msg = exist.ColumnName + "为必选列!"
  124. return
  125. }
  126. }
  127. tmp := new(data_stat.EdbInfoStatColumn)
  128. tmp.Id = v.Id
  129. tmp.Sort = k + 1
  130. tmp.IsShow = v.IsShow
  131. list = append(list, tmp)
  132. }
  133. err = data_stat.UpdateStatColumn(list)
  134. if err != nil {
  135. br.Msg = "更新自定义列操作失败!"
  136. br.ErrMsg = "更新自定义列操作失败,Err:" + err.Error()
  137. return
  138. }
  139. br.Ret = 200
  140. br.Success = true
  141. br.Msg = "获取成功"
  142. return
  143. }
  144. // EdbDeleteLog
  145. // @Title 查询删除指标列表
  146. // @Description 查询删除指标列表接口
  147. // @Success 200 {object} data_stat.GetEdbDeleteLogResp
  148. // @router /edb_delete_log [get]
  149. func (this *EdbSourceStatController) EdbDeleteLog() {
  150. br := new(models.BaseResponse).Init()
  151. defer func() {
  152. this.Data["json"] = br
  153. this.ServeJSON()
  154. }()
  155. sysUser := this.SysUser
  156. if sysUser == nil {
  157. br.Msg = "请登录"
  158. br.ErrMsg = "请登录,SysUser Is Empty"
  159. br.Ret = 408
  160. return
  161. }
  162. source, _ := this.GetInt("Source", -1)
  163. if source < 0 {
  164. br.Msg = "请选择数据源"
  165. return
  166. }
  167. sortParamReq := this.GetString("SortParam", "")
  168. sortType := this.GetString("SortType", "desc")
  169. createTime := this.GetString("CreateTime", "")
  170. pageSize, _ := this.GetInt("PageSize")
  171. currentIndex, _ := this.GetInt("CurrentIndex")
  172. var startSize int
  173. if pageSize <= 0 {
  174. pageSize = utils.PageSize20
  175. }
  176. if currentIndex <= 0 {
  177. currentIndex = 1
  178. }
  179. startSize = paging.StartIndex(currentIndex, pageSize)
  180. condition := " and source = ?"
  181. var pars []interface{}
  182. pars = append(pars, source)
  183. if createTime != "" {
  184. startT, err := time.ParseInLocation(utils.FormatDate, createTime, time.Local)
  185. if err != nil {
  186. br.Msg = "请求时间格式错误"
  187. return
  188. }
  189. endT := startT.AddDate(0, 0, 1)
  190. condition += " AND create_time >= ? AND create_time < ?"
  191. pars = append(pars, createTime, endT.Format(utils.FormatDate))
  192. }
  193. sortStr := ``
  194. sortParam := ``
  195. if sortParamReq != `` {
  196. switch sortParamReq {
  197. case "CreateTime":
  198. sortParam = "create_time"
  199. case "DataUpdateTime":
  200. sortParam = "data_update_time"
  201. case "ErDataUpdateDate":
  202. sortParam = "er_data_update_date"
  203. case "LatestDate":
  204. sortParam = "latest_date"
  205. case "StartDate":
  206. sortParam = "start_date"
  207. }
  208. if sortParam == "" {
  209. br.Msg = "请输入正确的排序字段"
  210. return
  211. }
  212. if strings.ToLower(sortType) != "asc" && strings.ToLower(sortType) != "desc" {
  213. br.Msg = "请输入正确的排序类型"
  214. return
  215. }
  216. sortStr = fmt.Sprintf(" order by %s %s, id desc ", sortParam, sortType)
  217. }
  218. total, err := data_stat.GetEdbDeleteLogCount(condition, pars)
  219. if err != nil {
  220. if !utils.IsErrNoRow(err) {
  221. br.Msg = "获取指标删除列表总数失败"
  222. br.ErrMsg = "获取指标删除列表总数失败,Err:" + err.Error()
  223. return
  224. } else {
  225. err = nil
  226. }
  227. }
  228. list := make([]*data_stat.EdbInfoDeleteLogItem, 0)
  229. page := paging.GetPaging(currentIndex, pageSize, total)
  230. if total == 0 {
  231. resp := data_stat.GetEdbDeleteLogResp{
  232. Paging: page,
  233. List: list,
  234. }
  235. br.Ret = 200
  236. br.Success = true
  237. br.Msg = "获取成功"
  238. br.Data = resp
  239. return
  240. }
  241. tmpList, err := data_stat.GetEdbDeleteLogByCondition(condition, pars, sortStr, pageSize, startSize)
  242. if err != nil {
  243. br.Msg = "获取指标删除列表失败"
  244. br.ErrMsg = "获取指标删除列表失败,Err:" + err.Error()
  245. return
  246. }
  247. for _, v := range tmpList {
  248. tmp := new(data_stat.EdbInfoDeleteLogItem)
  249. tmp.EdbCode = v.EdbCode
  250. tmp.EdbInfoId = v.EdbInfoId
  251. tmp.Id = v.Id
  252. tmp.StartDate = v.StartDate
  253. tmp.EndDate = v.EndDate
  254. tmp.Unit = v.Unit
  255. tmp.TerminalCode = v.TerminalCode
  256. tmp.CreateTime = v.CreateTime
  257. tmp.EdbCreateTime = v.EdbCreateTime
  258. tmp.Frequency = v.Frequency
  259. tmp.Source = v.Source
  260. tmp.SourceName = v.SourceName
  261. tmp.EdbName = v.EdbName
  262. tmp.EdbNameEn = v.EdbNameEn
  263. tmp.EdbNameSource = v.EdbNameSource
  264. tmp.LatestDate = v.LatestDate
  265. tmp.DelSysUserId = v.DelSysUserId
  266. tmp.DelSysUserRealName = v.DelSysUserRealName
  267. tmp.SysUserId = v.SysUserId
  268. tmp.SysUserRealName = v.SysUserRealName
  269. tmp.LatestValue = v.LatestValue
  270. if v.DataUpdateTime != utils.EmptyDateTimeStr {
  271. tmp.DataUpdateTime = v.DataUpdateTime
  272. }
  273. if v.ErDataUpdateDate != utils.EmptyDateStr {
  274. tmp.ErDataUpdateDate = v.ErDataUpdateDate
  275. }
  276. list = append(list, tmp)
  277. }
  278. resp := data_stat.GetEdbDeleteLogResp{
  279. Paging: page,
  280. List: list,
  281. }
  282. br.Ret = 200
  283. br.Success = true
  284. br.Msg = "获取成功"
  285. br.Data = resp
  286. }
  287. // EdbUpdateLog
  288. // @Title 查询指标信息变更列表
  289. // @Description 查询指标信息变更列表接口
  290. // @Success 200 {object} data_stat.GetEdbUpdateLogResp
  291. // @router /edb_update_log [get]
  292. func (this *EdbSourceStatController) EdbUpdateLog() {
  293. br := new(models.BaseResponse).Init()
  294. defer func() {
  295. this.Data["json"] = br
  296. this.ServeJSON()
  297. }()
  298. sysUser := this.SysUser
  299. if sysUser == nil {
  300. br.Msg = "请登录"
  301. br.ErrMsg = "请登录,SysUser Is Empty"
  302. br.Ret = 408
  303. return
  304. }
  305. source, _ := this.GetInt("Source", -1)
  306. if source < 0 {
  307. br.Msg = "请选择数据源"
  308. return
  309. }
  310. sortParamReq := this.GetString("SortParam", "")
  311. sortType := this.GetString("SortType", "desc")
  312. createTime := this.GetString("CreateTime", "")
  313. updateType, _ := this.GetInt("UpdateType", -1)
  314. pageSize, _ := this.GetInt("PageSize")
  315. currentIndex, _ := this.GetInt("CurrentIndex")
  316. var startSize int
  317. if pageSize <= 0 {
  318. pageSize = utils.PageSize20
  319. }
  320. if currentIndex <= 0 {
  321. currentIndex = 1
  322. }
  323. startSize = paging.StartIndex(currentIndex, pageSize)
  324. condition := " and source = ? and (data_update_result=1 or data_update_result=0)"
  325. var pars []interface{}
  326. pars = append(pars, source)
  327. if createTime != "" {
  328. startT, err := time.ParseInLocation(utils.FormatDate, createTime, time.Local)
  329. if err != nil {
  330. br.Msg = "请求时间格式错误"
  331. return
  332. }
  333. endT := startT.AddDate(0, 0, 1)
  334. condition += " AND create_time >= ? AND create_time < ?"
  335. pars = append(pars, createTime, endT.Format(utils.FormatDate))
  336. }
  337. if updateType >= 0 {
  338. condition += " AND update_type =? "
  339. pars = append(pars, updateType)
  340. }
  341. sortStr := ``
  342. sortParam := ``
  343. if sortParamReq != `` {
  344. switch sortParamReq {
  345. case "CreateTime":
  346. sortParam = "create_time"
  347. case "DataUpdateTime":
  348. sortParam = "data_update_time"
  349. case "ErDataUpdateDate":
  350. sortParam = "er_data_update_date"
  351. case "LatestDate":
  352. sortParam = "latest_date"
  353. case "StartDate":
  354. sortParam = "start_date"
  355. }
  356. if sortParam == "" {
  357. br.Msg = "请输入正确的排序字段"
  358. return
  359. }
  360. if strings.ToLower(sortType) != "asc" && strings.ToLower(sortType) != "desc" {
  361. br.Msg = "请输入正确的排序类型"
  362. return
  363. }
  364. sortStr = fmt.Sprintf(" order by %s %s, id desc ", sortParam, sortType)
  365. }
  366. total, err := data_stat.GetEdbUpdateLogCount(condition, pars)
  367. if err != nil {
  368. if !utils.IsErrNoRow(err) {
  369. br.Msg = "获取指标删除列表总数失败"
  370. br.ErrMsg = "获取指标删除列表总数失败,Err:" + err.Error()
  371. return
  372. } else {
  373. err = nil
  374. }
  375. }
  376. list := make([]*data_stat.EdbInfoUpdateLogItem, 0)
  377. page := paging.GetPaging(currentIndex, pageSize, total)
  378. if total == 0 {
  379. resp := data_stat.GetEdbUpdateLogResp{
  380. Paging: page,
  381. List: list,
  382. }
  383. br.Ret = 200
  384. br.Success = true
  385. br.Msg = "获取成功"
  386. br.Data = resp
  387. return
  388. }
  389. tmpList, err := data_stat.GetEdbUpdateLogByCondition(condition, pars, sortStr, pageSize, startSize)
  390. if err != nil {
  391. br.Msg = "获取指标更新列表失败"
  392. br.ErrMsg = "获取指标更新列表失败,Err:" + err.Error()
  393. return
  394. }
  395. for _, v := range tmpList {
  396. tmp := new(data_stat.EdbInfoUpdateLogItem)
  397. tmp.Id = v.Id
  398. tmp.EdbInfoId = v.EdbInfoId
  399. tmp.SourceName = v.SourceName
  400. tmp.Source = v.Source
  401. tmp.EdbCode = v.EdbCode
  402. tmp.EdbName = v.EdbName
  403. tmp.EdbNameSource = v.EdbNameSource
  404. tmp.Frequency = v.Frequency
  405. tmp.Unit = v.Unit
  406. tmp.StartDate = v.StartDate
  407. tmp.EndDate = v.EndDate
  408. tmp.SysUserId = v.SysUserId
  409. tmp.SysUserRealName = v.SysUserRealName
  410. tmp.UpdateSysUserRealName = v.UpdateSysUserRealName
  411. tmp.UpdateSysUserId = v.UpdateSysUserId
  412. tmp.UniqueCode = v.UniqueCode
  413. tmp.CreateTime = v.CreateTime.Format(utils.FormatDateTime)
  414. tmp.LatestDate = v.LatestDate
  415. tmp.LatestValue = v.LatestValue
  416. tmp.TerminalCode = v.TerminalCode
  417. if v.DataUpdateTime != utils.EmptyDateTimeStr {
  418. tmp.DataUpdateTime = v.DataUpdateTime
  419. }
  420. if v.ErDataUpdateDate != utils.EmptyDateStr {
  421. tmp.ErDataUpdateDate = v.ErDataUpdateDate
  422. }
  423. tmp.UpdateType = v.UpdateType
  424. list = append(list, tmp)
  425. }
  426. resp := data_stat.GetEdbUpdateLogResp{
  427. Paging: page,
  428. List: list,
  429. }
  430. br.Ret = 200
  431. br.Success = true
  432. br.Msg = "获取成功"
  433. br.Data = resp
  434. }
  435. // EdbUpdateStat
  436. // @Title 查询数据源明细列表
  437. // @Description 查询数据源明细列表接口
  438. // @Success 200 {object} data_stat.GetEdbUpdateStatResp
  439. // @router /edb_update_stat [get]
  440. func (this *EdbSourceStatController) EdbUpdateStat() {
  441. br := new(models.BaseResponse).Init()
  442. defer func() {
  443. this.Data["json"] = br
  444. this.ServeJSON()
  445. }()
  446. sysUser := this.SysUser
  447. if sysUser == nil {
  448. br.Msg = "请登录"
  449. br.ErrMsg = "请登录,SysUser Is Empty"
  450. br.Ret = 408
  451. return
  452. }
  453. sortParamReq := this.GetString("SortParam", "")
  454. sortType := this.GetString("SortType", "desc")
  455. source, _ := this.GetInt("Source", -1)
  456. if source < 0 {
  457. br.Msg = "请选择数据源"
  458. return
  459. }
  460. terminalCode := this.GetString("TerminalCode", "")
  461. sysUserId := this.GetString("SysUserId", "")
  462. frequency := this.GetString("Frequency", "")
  463. keyWord := this.GetString("KeyWord", "") //指标编码/指标名称
  464. createTime := this.GetString("CreateTime", "")
  465. pageSize, _ := this.GetInt("PageSize")
  466. currentIndex, _ := this.GetInt("CurrentIndex")
  467. isApi, _ := this.GetInt("IsApi", 0)
  468. // 区分终端和API的统计
  469. // 查询类型为API的终端编码
  470. terminalCodeList, err := data_manage.GetTerminalCodeBySourceAndIsApi(source, isApi)
  471. if err != nil {
  472. br.Msg = "获取终端编码失败"
  473. br.ErrMsg = "获取终端编码失败,Err:" + err.Error()
  474. return
  475. }
  476. var startSize int
  477. if pageSize <= 0 {
  478. pageSize = utils.PageSize20
  479. }
  480. if currentIndex <= 0 {
  481. currentIndex = 1
  482. }
  483. startSize = paging.StartIndex(currentIndex, pageSize)
  484. condition := " and source = ? and terminal_code in (" + utils.GetOrmInReplace(len(terminalCodeList)) + ")"
  485. var pars []interface{}
  486. pars = append(pars, source)
  487. pars = append(pars, terminalCodeList)
  488. if createTime != "" {
  489. startT, err := time.ParseInLocation(utils.FormatDate, createTime, time.Local)
  490. if err != nil {
  491. br.Msg = "请求时间格式错误"
  492. return
  493. }
  494. endT := startT.AddDate(0, 0, 1)
  495. condition += " AND create_time >= ? AND create_time < ?"
  496. pars = append(pars, createTime, endT.Format(utils.FormatDate))
  497. }
  498. if terminalCode != "" {
  499. codeSlice := strings.Split(terminalCode, ",")
  500. condition += ` AND terminal_code IN (` + utils.GetOrmInReplace(len(codeSlice)) + `)`
  501. pars = append(pars, codeSlice)
  502. }
  503. if sysUserId != "" {
  504. sysUserIdSlice := strings.Split(sysUserId, ",")
  505. condition += ` AND sys_user_id IN (` + utils.GetOrmInReplace(len(sysUserIdSlice)) + `)`
  506. pars = append(pars, sysUserIdSlice)
  507. }
  508. if frequency != "" {
  509. frequencySlice := strings.Split(frequency, ",")
  510. condition += ` AND frequency IN (` + utils.GetOrmInReplace(len(frequencySlice)) + `)`
  511. pars = append(pars, frequencySlice)
  512. }
  513. if keyWord != "" {
  514. condition += ` AND (edb_name LIKE ? OR edb_code LIKE ? ) `
  515. pars = append(pars, "%"+keyWord+"%", "%"+keyWord+"%")
  516. }
  517. sortStr := ``
  518. sortParam := ``
  519. if sortParamReq != `` {
  520. switch sortParamReq {
  521. case "CreateTime":
  522. sortParam = "create_time"
  523. case "UpdateTime":
  524. sortParam = "update_time"
  525. case "DataUpdateTime":
  526. sortParam = "data_update_time"
  527. case "ErDataUpdateDate":
  528. sortParam = "er_data_update_date"
  529. case "LatestDate":
  530. sortParam = "latest_date"
  531. case "StartDate":
  532. sortParam = "start_date"
  533. }
  534. if sortParam == "" {
  535. br.Msg = "请输入正确的排序字段"
  536. return
  537. }
  538. if strings.ToLower(sortType) != "asc" && strings.ToLower(sortType) != "desc" {
  539. br.Msg = "请输入正确的排序类型"
  540. return
  541. }
  542. sortStr = fmt.Sprintf(" order by %s %s, id desc ", sortParam, sortType)
  543. }
  544. total, err := data_stat.GetEdbUpdateStatCount(condition, pars)
  545. if err != nil {
  546. if !utils.IsErrNoRow(err) {
  547. br.Msg = "获取指标列表总数失败"
  548. br.ErrMsg = "获取指标列表总数失败,Err:" + err.Error()
  549. return
  550. } else {
  551. err = nil
  552. }
  553. }
  554. list := make([]*data_stat.EdbInfoUpdateStatItemMore, 0)
  555. page := paging.GetPaging(currentIndex, pageSize, total)
  556. if total == 0 {
  557. resp := data_stat.GetEdbUpdateStatResp{
  558. Paging: page,
  559. List: list,
  560. }
  561. br.Ret = 200
  562. br.Success = true
  563. br.Msg = "获取成功"
  564. br.Data = resp
  565. return
  566. }
  567. tmpList, err := data_stat.GetEdbUpdateStatByCondition(condition, pars, sortStr, pageSize, startSize)
  568. if err != nil {
  569. br.Msg = "获取指标更新列表失败"
  570. br.ErrMsg = "获取指标更新列表失败,Err:" + err.Error()
  571. return
  572. }
  573. // 获取初始数据源名称
  574. var edbCodeList []string
  575. for _, v := range tmpList {
  576. edbCodeList = append(edbCodeList, v.EdbCode)
  577. }
  578. initSourceMap := make(map[string]string)
  579. if len(edbCodeList) > 0 {
  580. baseCond := " and index_code in (" + utils.GetOrmInReplace(len(edbCodeList)) + ")"
  581. var basePars []interface{}
  582. basePars = append(basePars, edbCodeList)
  583. indexList, tErr := data_manage.GetMysteelChemicalIndexList(baseCond, basePars, 0, 1000, "")
  584. if tErr != nil {
  585. br.Msg = "获取初始指标信息失败"
  586. br.ErrMsg = "获取初始指标信息失败,Err:" + tErr.Error()
  587. return
  588. }
  589. for _, v := range indexList {
  590. initSourceMap[v.IndexCode] = v.Source
  591. }
  592. }
  593. for _, v := range tmpList {
  594. tmp := new(data_stat.EdbInfoUpdateStatItemMore)
  595. tmp.Id = v.Id
  596. tmp.EdbInfoId = v.EdbInfoId
  597. tmp.SourceName = v.SourceName
  598. tmp.Source = v.Source
  599. tmp.EdbCode = v.EdbCode
  600. tmp.EdbName = v.EdbName
  601. tmp.EdbNameSource = v.EdbNameSource
  602. tmp.Frequency = v.Frequency
  603. tmp.Unit = v.Unit
  604. tmp.StartDate = v.StartDate
  605. tmp.SysUserId = v.SysUserId
  606. tmp.SysUserRealName = v.SysUserRealName
  607. tmp.LatestDate = v.LatestDate
  608. tmp.LatestValue = v.LatestValue
  609. tmp.TerminalCode = v.TerminalCode
  610. if v.DataUpdateTime != utils.EmptyDateTimeStr {
  611. tmp.DataUpdateTime = v.DataUpdateTime
  612. }
  613. if v.ErDataUpdateDate != utils.EmptyDateStr {
  614. tmp.ErDataUpdateDate = v.ErDataUpdateDate
  615. }
  616. tmp.DataUpdateResult = v.DataUpdateResult
  617. tmp.DataUpdateFailedReason = v.DataUpdateFailedReason
  618. if v.UpdateTime != utils.EmptyDateTimeStr {
  619. tmp.UpdateTime = v.UpdateTime
  620. }
  621. tmp.IsAdd = v.IsAdd
  622. tmp.NeedRefresh = v.NeedRefresh
  623. tmp.HasRefresh = v.HasRefresh
  624. tmp.InitSourceName, _ = initSourceMap[v.EdbCode]
  625. list = append(list, tmp)
  626. }
  627. resp := data_stat.GetEdbUpdateStatResp{
  628. Paging: page,
  629. List: list,
  630. }
  631. br.Ret = 200
  632. br.Success = true
  633. br.Msg = "获取成功"
  634. br.Data = resp
  635. }
  636. // EdbSourceStat
  637. // @Title 查询数据源统计列表
  638. // @Description 查询数据源统计列表接口
  639. // @Success 200 {object} data_stat.GetEdbUpdateLogResp
  640. // @router /source_stat [get]
  641. func (this *EdbSourceStatController) EdbSourceStat() {
  642. br := new(models.BaseResponse).Init()
  643. defer func() {
  644. this.Data["json"] = br
  645. this.ServeJSON()
  646. }()
  647. sysUser := this.SysUser
  648. if sysUser == nil {
  649. br.Msg = "请登录"
  650. br.ErrMsg = "请登录,SysUser Is Empty"
  651. br.Ret = 408
  652. return
  653. }
  654. source, _ := this.GetInt("Source", -1)
  655. if source < 0 {
  656. br.Msg = "请选择数据源"
  657. return
  658. }
  659. sortParamReq := this.GetString("SortParam", "")
  660. sortType := this.GetString("SortType", "desc")
  661. createTime := this.GetString("CreateTime", "")
  662. pageSize, _ := this.GetInt("PageSize")
  663. currentIndex, _ := this.GetInt("CurrentIndex")
  664. isApi, _ := this.GetInt("IsApi", 0)
  665. var startSize int
  666. if pageSize <= 0 {
  667. pageSize = utils.PageSize20
  668. }
  669. if currentIndex <= 0 {
  670. currentIndex = 1
  671. }
  672. startSize = paging.StartIndex(currentIndex, pageSize)
  673. // 区分终端和API的统计
  674. // 查询类型为API的终端编码
  675. terminalCodeList, err := data_manage.GetTerminalCodeBySourceAndIsApi(source, isApi)
  676. if err != nil {
  677. br.Msg = "获取终端编码失败"
  678. br.ErrMsg = "获取终端编码失败,Err:" + err.Error()
  679. return
  680. }
  681. condition := " and source = ? and terminal_code in (" + utils.GetOrmInReplace(len(terminalCodeList)) + ")"
  682. var pars []interface{}
  683. pars = append(pars, source)
  684. pars = append(pars, terminalCodeList)
  685. if createTime != "" {
  686. startT, err := time.ParseInLocation(utils.FormatDate, createTime, time.Local)
  687. if err != nil {
  688. br.Msg = "请求时间格式错误"
  689. return
  690. }
  691. endT := startT.AddDate(0, 0, 1)
  692. condition += " AND create_time >= ? AND create_time < ?"
  693. pars = append(pars, createTime, endT.Format(utils.FormatDate))
  694. }
  695. sortStr := ``
  696. sortParam := ``
  697. if sortParamReq != `` {
  698. switch sortParamReq {
  699. case "EdbNum":
  700. sortParam = "edb_num"
  701. case "NeedRefreshNum":
  702. sortParam = "need_refresh_num"
  703. case "hasRefreshNum":
  704. sortParam = "has_refresh_num"
  705. case "UpdateSuccessNum":
  706. sortParam = "update_success_num"
  707. case "UpdateFailedNum":
  708. sortParam = "update_failed_num"
  709. }
  710. if sortParam == "" {
  711. br.Msg = "请输入正确的排序字段"
  712. return
  713. }
  714. if strings.ToLower(sortType) != "asc" && strings.ToLower(sortType) != "desc" {
  715. br.Msg = "请输入正确的排序类型"
  716. return
  717. }
  718. sortStr = fmt.Sprintf(" order by %s %s, id desc ", sortParam, sortType)
  719. }
  720. total, err := data_stat.GetEdbSourceStatCount(condition, pars)
  721. if err != nil {
  722. if !utils.IsErrNoRow(err) {
  723. br.Msg = "获取数据源统计列表总数失败"
  724. br.ErrMsg = "获取数据源统计列表总数失败,Err:" + err.Error()
  725. return
  726. } else {
  727. err = nil
  728. }
  729. }
  730. list := make([]*data_stat.EdbInfoSourceStatItem, 0)
  731. page := paging.GetPaging(currentIndex, pageSize, total)
  732. if total == 0 {
  733. resp := data_stat.GetEdbSourceStatResp{
  734. Paging: page,
  735. List: list,
  736. }
  737. br.Ret = 200
  738. br.Success = true
  739. br.Msg = "获取成功"
  740. br.Data = resp
  741. return
  742. }
  743. tmpList, err := data_stat.GetEdbSourceStatByCondition(condition, pars, sortStr, pageSize, startSize)
  744. if err != nil {
  745. br.Msg = "获取指标删除列表失败"
  746. br.ErrMsg = "获取指标删除列表失败,Err:" + err.Error()
  747. return
  748. }
  749. for _, v := range tmpList {
  750. tmp := new(data_stat.EdbInfoSourceStatItem)
  751. tmp.Id = v.Id
  752. tmp.SourceName = v.SourceName
  753. tmp.Source = v.Source
  754. tmp.TerminalCode = v.TerminalCode
  755. tmp.EdbNum = v.EdbNum
  756. tmp.EdbNewNum = v.EdbNewNum
  757. tmp.EdbDelNum = v.EdbDelNum
  758. tmp.NeedRefreshNum = v.NeedRefreshNum
  759. tmp.HasRefreshNum = v.HasRefreshNum
  760. tmp.UpdateSuccessNum = v.UpdateSuccessNum
  761. tmp.UpdateFailedNum = v.UpdateFailedNum
  762. tmp.RefreshSuccessNum = v.RefreshSuccessNum
  763. tmp.RefreshFailedNum = v.RefreshFailedNum
  764. list = append(list, tmp)
  765. }
  766. resp := data_stat.GetEdbSourceStatResp{
  767. Paging: page,
  768. List: list,
  769. }
  770. br.Ret = 200
  771. br.Success = true
  772. br.Msg = "获取成功"
  773. br.Data = resp
  774. }
  775. // EdbUpdateFailedList
  776. // @Title 查询指标更新失败详情汇总列表
  777. // @Description 查询指标更新失败详情汇总列表
  778. // @Success 200 {object} data_stat.GetEdbUpdateLogResp
  779. // @router /edb_update_stat/failed [get]
  780. func (this *EdbSourceStatController) EdbUpdateFailedList() {
  781. br := new(models.BaseResponse).Init()
  782. defer func() {
  783. this.Data["json"] = br
  784. this.ServeJSON()
  785. }()
  786. sysUser := this.SysUser
  787. if sysUser == nil {
  788. br.Msg = "请登录"
  789. br.ErrMsg = "请登录,SysUser Is Empty"
  790. br.Ret = 408
  791. return
  792. }
  793. source, _ := this.GetInt("Source", -1)
  794. if source < 0 {
  795. br.Msg = "请选择数据源"
  796. return
  797. }
  798. terminalCode := this.GetString("TerminalCode", "")
  799. createTime := this.GetString("CreateTime", "")
  800. condition := " and source = ? and terminal_code = ?"
  801. var pars []interface{}
  802. pars = append(pars, source, terminalCode)
  803. terminalName := ""
  804. terminalDir := ""
  805. if terminalCode != "" {
  806. terminalInfo, err := data_manage.GetEdbTerminalByTerminalCode(terminalCode)
  807. if err != nil {
  808. if utils.IsErrNoRow(err) {
  809. br.Msg = "终端不存在"
  810. return
  811. }
  812. br.Msg = "查询终端信息出错"
  813. br.ErrMsg = "查询终端信息出错 Err:" + err.Error()
  814. return
  815. }
  816. terminalName = terminalInfo.Name
  817. terminalDir = terminalInfo.DirPath
  818. }
  819. if createTime != "" {
  820. startT, err := time.ParseInLocation(utils.FormatDate, createTime, time.Local)
  821. if err != nil {
  822. br.Msg = "请求时间格式错误"
  823. return
  824. }
  825. endT := startT.AddDate(0, 0, 1)
  826. condition += " AND create_time >= ? AND create_time < ?"
  827. pars = append(pars, createTime, endT.Format(utils.FormatDate))
  828. }
  829. tmpList, err := data_stat.GetEdbUpdateStatFailedGroupByCondition(condition, pars)
  830. if err != nil {
  831. br.Msg = "获取指标更新失败详情列表 失败"
  832. br.ErrMsg = "获取指标更新失败详情列表 失败,Err:" + err.Error()
  833. return
  834. }
  835. list := make([]*data_stat.EdbUpdateFailedList, 0)
  836. successNum := 0
  837. failedNum := 0
  838. if len(tmpList) > 0 {
  839. for _, v := range tmpList {
  840. if v.SourceUpdateResult == 1 {
  841. successNum += v.Num
  842. } else {
  843. failedNum += v.Num
  844. list = append(list, v)
  845. }
  846. }
  847. }
  848. resp := data_stat.GetEdbUpdateFailedResp{
  849. List: list,
  850. Name: terminalName,
  851. TerminalCode: terminalCode,
  852. DirPath: terminalDir,
  853. UpdateSuccessNum: successNum,
  854. UpdateFailedNum: failedNum,
  855. }
  856. br.Ret = 200
  857. br.Success = true
  858. br.Msg = "获取成功"
  859. br.Data = resp
  860. }
  861. // EdbUpdateFailedDetailList
  862. // @Title 查询指标更新失败详情列表
  863. // @Description 查询指标更新失败详情列表
  864. // @Success 200 {object} data_stat.GetEdbUpdateLogResp
  865. // @router /edb_update_stat/failed/detail [get]
  866. func (this *EdbSourceStatController) EdbUpdateFailedDetailList() {
  867. br := new(models.BaseResponse).Init()
  868. defer func() {
  869. this.Data["json"] = br
  870. this.ServeJSON()
  871. }()
  872. sysUser := this.SysUser
  873. if sysUser == nil {
  874. br.Msg = "请登录"
  875. br.ErrMsg = "请登录,SysUser Is Empty"
  876. br.Ret = 408
  877. return
  878. }
  879. source, _ := this.GetInt("Source", -1)
  880. if source < 0 {
  881. br.Msg = "请选择数据源"
  882. return
  883. }
  884. pageSize, _ := this.GetInt("PageSize")
  885. currentIndex, _ := this.GetInt("CurrentIndex")
  886. var startSize int
  887. if pageSize <= 0 {
  888. pageSize = utils.PageSize20
  889. }
  890. if currentIndex <= 0 {
  891. currentIndex = 1
  892. }
  893. startSize = paging.StartIndex(currentIndex, pageSize)
  894. terminalCode := this.GetString("TerminalCode", "")
  895. createTime := this.GetString("CreateTime", "")
  896. frequency := this.GetString("Frequency", "")
  897. sourceUpdateFailedReason := this.GetString("SourceUpdateFailedReason", "")
  898. if createTime == "" {
  899. br.Msg = "请选择创建时间"
  900. return
  901. }
  902. if frequency == "" {
  903. br.Msg = "请选择对应的频度"
  904. return
  905. }
  906. condition := " and source = ? AND terminal_code = ? and frequency=? and data_update_failed_reason=? and data_update_result = 2"
  907. var pars []interface{}
  908. pars = append(pars, source, terminalCode, frequency, sourceUpdateFailedReason)
  909. if createTime != "" {
  910. startT, err := time.ParseInLocation(utils.FormatDate, createTime, time.Local)
  911. if err != nil {
  912. br.Msg = "请求时间格式错误"
  913. return
  914. }
  915. endT := startT.AddDate(0, 0, 1)
  916. condition += " AND create_time >= ? AND create_time < ?"
  917. pars = append(pars, createTime, endT.Format(utils.FormatDate))
  918. }
  919. total, err := data_stat.GetEdbUpdateStatCount(condition, pars)
  920. if err != nil {
  921. if !utils.IsErrNoRow(err) {
  922. br.Msg = "获取指标列表总数失败"
  923. br.ErrMsg = "获取指标列表总数失败,Err:" + err.Error()
  924. return
  925. } else {
  926. err = nil
  927. }
  928. }
  929. list := make([]*data_stat.EdbInfoUpdateStatItemMore, 0)
  930. page := paging.GetPaging(currentIndex, pageSize, total)
  931. if total == 0 {
  932. resp := data_stat.GetEdbUpdateStatResp{
  933. Paging: page,
  934. List: list,
  935. }
  936. br.Ret = 200
  937. br.Success = true
  938. br.Msg = "获取成功"
  939. br.Data = resp
  940. return
  941. }
  942. tmpList, err := data_stat.GetEdbUpdateStatByCondition(condition, pars, "", pageSize, startSize)
  943. if err != nil {
  944. br.Msg = "获取指标更新列表失败"
  945. br.ErrMsg = "获取指标更新列表失败,Err:" + err.Error()
  946. return
  947. }
  948. for _, v := range tmpList {
  949. tmp := new(data_stat.EdbInfoUpdateStatItemMore)
  950. tmp.Id = v.Id
  951. tmp.EdbInfoId = v.EdbInfoId
  952. tmp.SourceName = v.SourceName
  953. tmp.Source = v.Source
  954. tmp.EdbCode = v.EdbCode
  955. tmp.EdbName = v.EdbName
  956. tmp.EdbNameSource = v.EdbNameSource
  957. tmp.Frequency = v.Frequency
  958. tmp.Unit = v.Unit
  959. tmp.StartDate = v.StartDate
  960. tmp.SysUserId = v.SysUserId
  961. tmp.SysUserRealName = v.SysUserRealName
  962. tmp.LatestDate = v.LatestDate
  963. tmp.LatestValue = v.LatestValue
  964. tmp.TerminalCode = v.TerminalCode
  965. tmp.CreateTime = v.CreateTime.Format(utils.FormatDateTime)
  966. if v.DataUpdateTime != utils.EmptyDateTimeStr {
  967. tmp.DataUpdateTime = v.DataUpdateTime
  968. }
  969. if v.ErDataUpdateDate != utils.EmptyDateStr {
  970. tmp.ErDataUpdateDate = v.ErDataUpdateDate
  971. }
  972. tmp.DataUpdateResult = v.DataUpdateResult
  973. tmp.DataUpdateFailedReason = v.DataUpdateFailedReason
  974. if v.UpdateTime != utils.EmptyDateTimeStr {
  975. tmp.UpdateTime = v.UpdateTime
  976. }
  977. tmp.IsAdd = v.IsAdd
  978. tmp.NeedRefresh = v.NeedRefresh
  979. tmp.HasRefresh = v.HasRefresh
  980. list = append(list, tmp)
  981. }
  982. resp := data_stat.GetEdbUpdateStatResp{
  983. Paging: page,
  984. List: list,
  985. }
  986. br.Ret = 200
  987. br.Success = true
  988. br.Msg = "获取成功"
  989. br.Data = resp
  990. }