edb_source_stat.go 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729
  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_stat"
  7. "eta/eta_api/utils"
  8. "fmt"
  9. "github.com/rdlucklib/rdluck_tools/paging"
  10. "strings"
  11. "time"
  12. )
  13. // EdbSourceStatController 数据源统计表管理模块
  14. type EdbSourceStatController struct {
  15. controllers.BaseAuthController
  16. }
  17. // Column
  18. // @Title 数据源统计表自定义列列表
  19. // @Description 查询 数据源统计表自定义列列表
  20. // @Success 200 {object} data_stat.StatColumnList
  21. // @router /source_column [get]
  22. func (this *EdbSourceStatController) Column() {
  23. br := new(models.BaseResponse).Init()
  24. defer func() {
  25. this.Data["json"] = br
  26. this.ServeJSON()
  27. }()
  28. sysUser := this.SysUser
  29. if sysUser == nil {
  30. br.Msg = "请登录"
  31. br.ErrMsg = "请登录,SysUser Is Empty"
  32. br.Ret = 408
  33. return
  34. }
  35. columnType, _ := this.GetInt("ColumnType")
  36. if columnType <= 0 {
  37. br.Msg = "请选择表类型"
  38. return
  39. }
  40. tmpList, err := data_stat.GetStatColumn(columnType)
  41. if err != nil {
  42. br.Msg = "获取自定义列失败"
  43. br.ErrMsg = "获取自定义列失败,Err:" + err.Error()
  44. return
  45. }
  46. var list []*data_stat.EdbInfoStatColumnListItem
  47. for _, v := range tmpList {
  48. tmp := new(data_stat.EdbInfoStatColumnListItem)
  49. tmp.ColumnKey = v.ColumnKey
  50. tmp.IsShow = v.IsShow
  51. tmp.ColumnName = v.ColumnName
  52. tmp.Id = v.Id
  53. tmp.IsMust = v.IsMust
  54. tmp.IsSort = v.IsSort
  55. tmp.Type = v.Type
  56. list = append(list, tmp)
  57. }
  58. var statColumnList data_stat.StatColumnList
  59. statColumnList.List = list
  60. br.Ret = 200
  61. br.Success = true
  62. br.Msg = "获取成功"
  63. br.Data = statColumnList
  64. }
  65. // EditColumn
  66. // @Title 编辑数据源统计表自定义列
  67. // @Description 编辑 数据源统计表自定义列列表
  68. // @Success 200 {object} data_stat.StatColumnList
  69. // @router /source_column/edit [post]
  70. func (this *EdbSourceStatController) EditColumn() {
  71. br := new(models.BaseResponse).Init()
  72. defer func() {
  73. this.Data["json"] = br
  74. this.ServeJSON()
  75. }()
  76. sysUser := this.SysUser
  77. if sysUser == nil {
  78. br.Msg = "请登录"
  79. br.ErrMsg = "请登录,SysUser Is Empty"
  80. br.Ret = 408
  81. return
  82. }
  83. var req data_stat.EditStatColumnReq
  84. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  85. if err != nil {
  86. br.Msg = "参数解析异常!"
  87. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  88. return
  89. }
  90. if len(req.List) <= 0 {
  91. br.Msg = "请选择要修改的列"
  92. br.IsSendEmail = false
  93. return
  94. }
  95. tmpList, err := data_stat.GetAllStatColumn()
  96. if err != nil {
  97. br.Msg = "获取自定义列失败"
  98. br.ErrMsg = "获取自定义列失败,Err:" + err.Error()
  99. return
  100. }
  101. isMustMap := make(map[int]data_stat.EdbInfoStatColumn)
  102. if len(tmpList) > 0 {
  103. for _, v := range tmpList {
  104. if v.IsMust == 1 {
  105. isMustMap[v.Id] = v
  106. }
  107. }
  108. }
  109. var list []*data_stat.EdbInfoStatColumn
  110. for k, v := range req.List {
  111. if v.Id == 0 {
  112. br.Msg = "列序号不能为空"
  113. return
  114. }
  115. if v.IsShow == 0 {
  116. if exist, ok := isMustMap[v.Id]; ok {
  117. br.Msg = exist.ColumnName + "为必选列!"
  118. return
  119. }
  120. }
  121. tmp := new(data_stat.EdbInfoStatColumn)
  122. tmp.Id = v.Id
  123. tmp.Sort = k + 1
  124. tmp.IsShow = v.IsShow
  125. list = append(list, tmp)
  126. }
  127. err = data_stat.UpdateStatColumn(list)
  128. if err != nil {
  129. br.Msg = "更新自定义列操作失败!"
  130. br.ErrMsg = "更新自定义列操作失败,Err:" + err.Error()
  131. return
  132. }
  133. br.Ret = 200
  134. br.Success = true
  135. br.Msg = "获取成功"
  136. return
  137. }
  138. // EdbDeleteLog
  139. // @Title 查询删除指标列表
  140. // @Description 查询删除指标列表接口
  141. // @Success 200 {object} data_stat.GetEdbDeleteLogResp
  142. // @router /edb_delete_log [get]
  143. func (this *EdbSourceStatController) EdbDeleteLog() {
  144. br := new(models.BaseResponse).Init()
  145. defer func() {
  146. this.Data["json"] = br
  147. this.ServeJSON()
  148. }()
  149. sysUser := this.SysUser
  150. if sysUser == nil {
  151. br.Msg = "请登录"
  152. br.ErrMsg = "请登录,SysUser Is Empty"
  153. br.Ret = 408
  154. return
  155. }
  156. sortParamReq := this.GetString("SortParam", "")
  157. sortType := this.GetString("SortType", "desc")
  158. createTime := this.GetString("CreateTime", "")
  159. pageSize, _ := this.GetInt("PageSize")
  160. currentIndex, _ := this.GetInt("CurrentIndex")
  161. var startSize int
  162. if pageSize <= 0 {
  163. pageSize = utils.PageSize20
  164. }
  165. if currentIndex <= 0 {
  166. currentIndex = 1
  167. }
  168. startSize = paging.StartIndex(currentIndex, pageSize)
  169. condition := " and source = ?"
  170. var pars []interface{}
  171. pars = append(pars, utils.DATA_SOURCE_MYSTEEL_CHEMICAL)
  172. if createTime != "" {
  173. startT, err := time.ParseInLocation(utils.FormatDate, createTime, time.Local)
  174. if err != nil {
  175. br.Msg = "请求时间格式错误"
  176. return
  177. }
  178. endT := startT.AddDate(0, 0, 1)
  179. condition += " AND create_time >= ? AND create_time < ?"
  180. pars = append(pars, createTime, endT.Format(utils.FormatDate))
  181. }
  182. sortStr := ``
  183. sortParam := ``
  184. if sortParamReq != `` {
  185. switch sortParamReq {
  186. case "CreateTime":
  187. sortParam = "create_time"
  188. case "ErDataUpdateDate":
  189. sortParam = "er_data_update_date"
  190. case "LatestDate":
  191. sortParam = "latest_date"
  192. case "StartDate":
  193. sortParam = "start_date"
  194. }
  195. if sortParam == "" {
  196. br.Msg = "请输入正确的排序字段"
  197. return
  198. }
  199. if strings.ToLower(sortType) != "asc" && strings.ToLower(sortType) != "desc" {
  200. br.Msg = "请输入正确的排序类型"
  201. return
  202. }
  203. sortStr = fmt.Sprintf(" order by %s %s, id desc ", sortParam, sortType)
  204. }
  205. total, err := data_stat.GetEdbDeleteLogCount(condition, pars)
  206. if err != nil {
  207. if err.Error() != utils.ErrNoRow() {
  208. br.Msg = "获取指标删除列表总数失败"
  209. br.ErrMsg = "获取指标删除列表总数失败,Err:" + err.Error()
  210. return
  211. } else {
  212. err = nil
  213. }
  214. }
  215. list := make([]*data_stat.EdbInfoDeleteLogItem, 0)
  216. page := paging.GetPaging(currentIndex, pageSize, total)
  217. if total == 0 {
  218. resp := data_stat.GetEdbDeleteLogResp{
  219. Paging: page,
  220. List: list,
  221. }
  222. br.Ret = 200
  223. br.Success = true
  224. br.Msg = "获取成功"
  225. br.Data = resp
  226. return
  227. }
  228. tmpList, err := data_stat.GetEdbDeleteLogByCondition(condition, pars, sortStr, pageSize, startSize)
  229. if err != nil {
  230. br.Msg = "获取指标删除列表失败"
  231. br.ErrMsg = "获取指标删除列表失败,Err:" + err.Error()
  232. return
  233. }
  234. for _, v := range tmpList {
  235. tmp := new(data_stat.EdbInfoDeleteLogItem)
  236. tmp.EdbCode = v.EdbCode
  237. tmp.EdbInfoId = v.EdbInfoId
  238. tmp.Id = v.Id
  239. tmp.StartDate = v.StartDate
  240. tmp.Unit = v.Unit
  241. tmp.TerminalCode = v.TerminalCode
  242. tmp.CreateTime = v.CreateTime
  243. tmp.Frequency = v.Frequency
  244. tmp.Source = v.Source
  245. tmp.SourceName = v.SourceName
  246. tmp.EdbNameSource = v.EdbNameSource
  247. tmp.LatestDate = v.LatestDate
  248. tmp.DataUpdateTime = v.DataUpdateTime
  249. tmp.DelSysUserId = v.DelSysUserId
  250. tmp.DelSysUserRealName = v.DelSysUserRealName
  251. tmp.SysUserId = v.SysUserId
  252. tmp.LatestValue = v.LatestValue
  253. tmp.ErDataUpdateDate = v.ErDataUpdateDate
  254. list = append(list, tmp)
  255. }
  256. resp := data_stat.GetEdbDeleteLogResp{
  257. Paging: page,
  258. List: list,
  259. }
  260. br.Ret = 200
  261. br.Success = true
  262. br.Msg = "获取成功"
  263. br.Data = resp
  264. }
  265. // EdbUpdateLog
  266. // @Title 查询指标信息变更列表
  267. // @Description 查询指标信息变更列表接口
  268. // @Success 200 {object} data_stat.GetEdbUpdateLogResp
  269. // @router /edb_update_log [get]
  270. func (this *EdbSourceStatController) EdbUpdateLog() {
  271. br := new(models.BaseResponse).Init()
  272. defer func() {
  273. this.Data["json"] = br
  274. this.ServeJSON()
  275. }()
  276. sysUser := this.SysUser
  277. if sysUser == nil {
  278. br.Msg = "请登录"
  279. br.ErrMsg = "请登录,SysUser Is Empty"
  280. br.Ret = 408
  281. return
  282. }
  283. sortParamReq := this.GetString("SortParam", "")
  284. sortType := this.GetString("SortType", "desc")
  285. createTime := this.GetString("CreateTime", "")
  286. pageSize, _ := this.GetInt("PageSize")
  287. currentIndex, _ := this.GetInt("CurrentIndex")
  288. var startSize int
  289. if pageSize <= 0 {
  290. pageSize = utils.PageSize20
  291. }
  292. if currentIndex <= 0 {
  293. currentIndex = 1
  294. }
  295. startSize = paging.StartIndex(currentIndex, pageSize)
  296. condition := " and source = ?"
  297. var pars []interface{}
  298. pars = append(pars, utils.DATA_SOURCE_MYSTEEL_CHEMICAL)
  299. if createTime != "" {
  300. startT, err := time.ParseInLocation(utils.FormatDate, createTime, time.Local)
  301. if err != nil {
  302. br.Msg = "请求时间格式错误"
  303. return
  304. }
  305. endT := startT.AddDate(0, 0, 1)
  306. condition += " AND create_time >= ? AND create_time < ?"
  307. pars = append(pars, createTime, endT.Format(utils.FormatDate))
  308. }
  309. sortStr := ``
  310. sortParam := ``
  311. if sortParamReq != `` {
  312. switch sortParamReq {
  313. case "CreateTime":
  314. sortParam = "create_time"
  315. case "DataUpdateTime":
  316. sortParam = "data_update_time"
  317. case "ErDataUpdateDate":
  318. sortParam = "er_data_update_date"
  319. case "LatestDate":
  320. sortParam = "latest_date"
  321. case "StartDate":
  322. sortParam = "start_date"
  323. }
  324. if sortParam == "" {
  325. br.Msg = "请输入正确的排序字段"
  326. return
  327. }
  328. if strings.ToLower(sortType) != "asc" && strings.ToLower(sortType) != "desc" {
  329. br.Msg = "请输入正确的排序类型"
  330. return
  331. }
  332. sortStr = fmt.Sprintf(" order by %s %s, id desc ", sortParam, sortType)
  333. }
  334. total, err := data_stat.GetEdbUpdateLogCount(condition, pars)
  335. if err != nil {
  336. if err.Error() != utils.ErrNoRow() {
  337. br.Msg = "获取指标删除列表总数失败"
  338. br.ErrMsg = "获取指标删除列表总数失败,Err:" + err.Error()
  339. return
  340. } else {
  341. err = nil
  342. }
  343. }
  344. list := make([]*data_stat.EdbInfoUpdateLogItem, 0)
  345. page := paging.GetPaging(currentIndex, pageSize, total)
  346. if total == 0 {
  347. resp := data_stat.GetEdbUpdateLogResp{
  348. Paging: page,
  349. List: list,
  350. }
  351. br.Ret = 200
  352. br.Success = true
  353. br.Msg = "获取成功"
  354. br.Data = resp
  355. return
  356. }
  357. tmpList, err := data_stat.GetEdbUpdateLogByCondition(condition, pars, sortStr, pageSize, startSize)
  358. if err != nil {
  359. br.Msg = "获取指标更新列表失败"
  360. br.ErrMsg = "获取指标更新列表失败,Err:" + err.Error()
  361. return
  362. }
  363. for _, v := range tmpList {
  364. tmp := new(data_stat.EdbInfoUpdateLogItem)
  365. tmp.Id = v.Id
  366. tmp.EdbInfoId = v.EdbInfoId
  367. tmp.SourceName = v.SourceName
  368. tmp.Source = v.Source
  369. tmp.EdbCode = v.EdbCode
  370. tmp.EdbName = v.EdbName
  371. tmp.EdbNameSource = v.EdbNameSource
  372. tmp.Frequency = v.Frequency
  373. tmp.Unit = v.Unit
  374. tmp.StartDate = v.StartDate
  375. tmp.EndDate = v.EndDate
  376. tmp.SysUserId = v.SysUserId
  377. tmp.SysUserRealName = v.SysUserRealName
  378. tmp.UpdateSysUserRealName = v.UpdateSysUserRealName
  379. tmp.UpdateSysUserId = v.UpdateSysUserId
  380. tmp.UniqueCode = v.UniqueCode
  381. tmp.CreateTime = v.CreateTime.Format(utils.FormatDateTime)
  382. tmp.LatestDate = v.LatestDate
  383. tmp.LatestValue = v.LatestValue
  384. tmp.TerminalCode = v.TerminalCode
  385. tmp.DataUpdateTime = v.DataUpdateTime
  386. tmp.ErDataUpdateDate = v.ErDataUpdateDate
  387. list = append(list, tmp)
  388. }
  389. resp := data_stat.GetEdbUpdateLogResp{
  390. Paging: page,
  391. List: list,
  392. }
  393. br.Ret = 200
  394. br.Success = true
  395. br.Msg = "获取成功"
  396. br.Data = resp
  397. }
  398. // EdbUpdateStat
  399. // @Title 查询数据源明细列表
  400. // @Description 查询数据源明细列表接口
  401. // @Success 200 {object} data_stat.GetEdbUpdateStatResp
  402. // @router /edb_update_stat [get]
  403. func (this *EdbSourceStatController) EdbUpdateStat() {
  404. br := new(models.BaseResponse).Init()
  405. defer func() {
  406. this.Data["json"] = br
  407. this.ServeJSON()
  408. }()
  409. sysUser := this.SysUser
  410. if sysUser == nil {
  411. br.Msg = "请登录"
  412. br.ErrMsg = "请登录,SysUser Is Empty"
  413. br.Ret = 408
  414. return
  415. }
  416. sortParamReq := this.GetString("SortParam", "")
  417. sortType := this.GetString("SortType", "desc")
  418. terminalCode := this.GetString("TerminalCode", "")
  419. sysUserId, _ := this.GetInt("SysUserId")
  420. frequency := this.GetString("Frequency", "")
  421. keyWord := this.GetString("KeyWord", "") //指标编码/指标名称
  422. createTime := this.GetString("CreateTime", "")
  423. pageSize, _ := this.GetInt("PageSize")
  424. currentIndex, _ := this.GetInt("CurrentIndex")
  425. var startSize int
  426. if pageSize <= 0 {
  427. pageSize = utils.PageSize20
  428. }
  429. if currentIndex <= 0 {
  430. currentIndex = 1
  431. }
  432. startSize = paging.StartIndex(currentIndex, pageSize)
  433. condition := " and source = ?"
  434. var pars []interface{}
  435. pars = append(pars, utils.DATA_SOURCE_MYSTEEL_CHEMICAL)
  436. if createTime != "" {
  437. startT, err := time.ParseInLocation(utils.FormatDate, createTime, time.Local)
  438. if err != nil {
  439. br.Msg = "请求时间格式错误"
  440. return
  441. }
  442. endT := startT.AddDate(0, 0, 1)
  443. condition += " AND create_time >= ? AND create_time < ?"
  444. pars = append(pars, createTime, endT.Format(utils.FormatDate))
  445. }
  446. if terminalCode != "" {
  447. condition += " AND terminal_code = ?"
  448. pars = append(pars, terminalCode)
  449. }
  450. if sysUserId > 0 {
  451. condition += " AND sys_user_id = ?"
  452. pars = append(pars, sysUserId)
  453. }
  454. if frequency != "" {
  455. condition += " AND frequency = ?"
  456. pars = append(pars, frequency)
  457. }
  458. if keyWord != "" {
  459. condition += ` AND (edb_name LIKE ? OR edb_code LIKE ? ) `
  460. pars = append(pars, "%"+keyWord+"%", "%"+keyWord+"%")
  461. }
  462. sortStr := ``
  463. sortParam := ``
  464. if sortParamReq != `` {
  465. switch sortParamReq {
  466. case "CreateTime":
  467. sortParam = "create_time"
  468. case "DataUpdateTime":
  469. sortParam = "data_update_time"
  470. case "ErDataUpdateDate":
  471. sortParam = "er_data_update_date"
  472. case "LatestDate":
  473. sortParam = "latest_date"
  474. case "StartDate":
  475. sortParam = "start_date"
  476. }
  477. if sortParam == "" {
  478. br.Msg = "请输入正确的排序字段"
  479. return
  480. }
  481. if strings.ToLower(sortType) != "asc" && strings.ToLower(sortType) != "desc" {
  482. br.Msg = "请输入正确的排序类型"
  483. return
  484. }
  485. sortStr = fmt.Sprintf(" order by %s %s, id desc ", sortParam, sortType)
  486. }
  487. total, err := data_stat.GetEdbUpdateStatCount(condition, pars)
  488. if err != nil {
  489. if err.Error() != utils.ErrNoRow() {
  490. br.Msg = "获取指标删除列表总数失败"
  491. br.ErrMsg = "获取指标删除列表总数失败,Err:" + err.Error()
  492. return
  493. } else {
  494. err = nil
  495. }
  496. }
  497. list := make([]*data_stat.EdbInfoUpdateStatItem, 0)
  498. page := paging.GetPaging(currentIndex, pageSize, total)
  499. if total == 0 {
  500. resp := data_stat.GetEdbUpdateStatResp{
  501. Paging: page,
  502. List: list,
  503. }
  504. br.Ret = 200
  505. br.Success = true
  506. br.Msg = "获取成功"
  507. br.Data = resp
  508. return
  509. }
  510. tmpList, err := data_stat.GetEdbUpdateStatByCondition(condition, pars, sortStr, pageSize, startSize)
  511. if err != nil {
  512. br.Msg = "获取指标更新列表失败"
  513. br.ErrMsg = "获取指标更新列表失败,Err:" + err.Error()
  514. return
  515. }
  516. for _, v := range tmpList {
  517. tmp := new(data_stat.EdbInfoUpdateStatItem)
  518. tmp.Id = v.Id
  519. tmp.EdbInfoId = v.EdbInfoId
  520. tmp.SourceName = v.SourceName
  521. tmp.Source = v.Source
  522. tmp.EdbCode = v.EdbCode
  523. tmp.EdbName = v.EdbName
  524. tmp.EdbNameSource = v.EdbNameSource
  525. tmp.Frequency = v.Frequency
  526. tmp.Unit = v.Unit
  527. tmp.StartDate = v.StartDate
  528. tmp.SysUserId = v.SysUserId
  529. tmp.SysUserRealName = v.SysUserRealName
  530. tmp.LatestDate = v.LatestDate
  531. tmp.LatestValue = v.LatestValue
  532. tmp.TerminalCode = v.TerminalCode
  533. tmp.DataUpdateTime = v.DataUpdateTime.Format(utils.FormatDateTime)
  534. tmp.ErDataUpdateDate = v.ErDataUpdateDate.Format(utils.FormatDate)
  535. tmp.SourceUpdateResult = v.SourceUpdateResult
  536. tmp.SourceUpdateFailedReason = v.SourceUpdateFailedReason
  537. tmp.SourceUpdateTime = v.SourceUpdateTime
  538. tmp.IsAdd = v.IsAdd
  539. tmp.NeedRefresh = v.NeedRefresh
  540. tmp.HasRefresh = v.HasRefresh
  541. list = append(list, tmp)
  542. }
  543. resp := data_stat.GetEdbUpdateStatResp{
  544. Paging: page,
  545. List: list,
  546. }
  547. br.Ret = 200
  548. br.Success = true
  549. br.Msg = "获取成功"
  550. br.Data = resp
  551. }
  552. // EdbSourceStat
  553. // @Title 查询数据源统计列表
  554. // @Description 查询数据源统计列表接口
  555. // @Success 200 {object} data_stat.GetEdbUpdateLogResp
  556. // @router /source_stat [get]
  557. func (this *EdbSourceStatController) EdbSourceStat() {
  558. br := new(models.BaseResponse).Init()
  559. defer func() {
  560. this.Data["json"] = br
  561. this.ServeJSON()
  562. }()
  563. sysUser := this.SysUser
  564. if sysUser == nil {
  565. br.Msg = "请登录"
  566. br.ErrMsg = "请登录,SysUser Is Empty"
  567. br.Ret = 408
  568. return
  569. }
  570. sortParamReq := this.GetString("SortParam", "")
  571. sortType := this.GetString("SortType", "desc")
  572. createTime := this.GetString("CreateTime", "")
  573. pageSize, _ := this.GetInt("PageSize")
  574. currentIndex, _ := this.GetInt("CurrentIndex")
  575. var startSize int
  576. if pageSize <= 0 {
  577. pageSize = utils.PageSize20
  578. }
  579. if currentIndex <= 0 {
  580. currentIndex = 1
  581. }
  582. startSize = paging.StartIndex(currentIndex, pageSize)
  583. condition := " and source = ?"
  584. var pars []interface{}
  585. pars = append(pars, utils.DATA_SOURCE_MYSTEEL_CHEMICAL)
  586. if createTime != "" {
  587. startT, err := time.ParseInLocation(utils.FormatDate, createTime, time.Local)
  588. if err != nil {
  589. br.Msg = "请求时间格式错误"
  590. return
  591. }
  592. endT := startT.AddDate(0, 0, 1)
  593. condition += " AND create_time >= ? AND create_time < ?"
  594. pars = append(pars, createTime, endT.Format(utils.FormatDate))
  595. }
  596. sortStr := ``
  597. sortParam := ``
  598. if sortParamReq != `` {
  599. switch sortParamReq {
  600. case "EdbNum":
  601. sortParam = "edb_num"
  602. case "NeedRefreshNum":
  603. sortParam = "need_refresh_num"
  604. case "hasRefreshNum":
  605. sortParam = "has_refresh_num"
  606. case "UpdateSuccessNum":
  607. sortParam = "update_success_num"
  608. case "UpdateFailedNum":
  609. sortParam = "update_failed_num"
  610. }
  611. if sortParam == "" {
  612. br.Msg = "请输入正确的排序字段"
  613. return
  614. }
  615. if strings.ToLower(sortType) != "asc" && strings.ToLower(sortType) != "desc" {
  616. br.Msg = "请输入正确的排序类型"
  617. return
  618. }
  619. sortStr = fmt.Sprintf(" order by %s %s, id desc ", sortParam, sortType)
  620. }
  621. total, err := data_stat.GetEdbSourceStatCount(condition, pars)
  622. if err != nil {
  623. if err.Error() != utils.ErrNoRow() {
  624. br.Msg = "获取指标删除列表总数失败"
  625. br.ErrMsg = "获取指标删除列表总数失败,Err:" + err.Error()
  626. return
  627. } else {
  628. err = nil
  629. }
  630. }
  631. list := make([]*data_stat.EdbInfoSourceStatItem, 0)
  632. page := paging.GetPaging(currentIndex, pageSize, total)
  633. if total == 0 {
  634. resp := data_stat.GetEdbSourceStatResp{
  635. Paging: page,
  636. List: list,
  637. }
  638. br.Ret = 200
  639. br.Success = true
  640. br.Msg = "获取成功"
  641. br.Data = resp
  642. return
  643. }
  644. tmpList, err := data_stat.GetEdbSourceStatByCondition(condition, pars, sortStr, pageSize, startSize)
  645. if err != nil {
  646. br.Msg = "获取指标删除列表失败"
  647. br.ErrMsg = "获取指标删除列表失败,Err:" + err.Error()
  648. return
  649. }
  650. for _, v := range tmpList {
  651. tmp := new(data_stat.EdbInfoSourceStatItem)
  652. tmp.Id = v.Id
  653. tmp.SourceName = v.SourceName
  654. tmp.Source = v.Source
  655. tmp.TerminalCode = v.TerminalCode
  656. tmp.EdbNum = v.EdbNum
  657. tmp.EdbNewNum = v.EdbNewNum
  658. tmp.EdbDelNum = v.EdbDelNum
  659. tmp.NeedUpdateNum = v.NeedUpdateNum
  660. tmp.HasUpdateNum = v.HasUpdateNum
  661. tmp.UpdateSuccessNum = v.UpdateSuccessNum
  662. tmp.UpdateFailedNum = v.UpdateFailedNum
  663. tmp.DataUpdateSuccessNum = v.DataUpdateSuccessNum
  664. list = append(list, tmp)
  665. }
  666. resp := data_stat.GetEdbSourceStatResp{
  667. Paging: page,
  668. List: list,
  669. }
  670. br.Ret = 200
  671. br.Success = true
  672. br.Msg = "获取成功"
  673. br.Data = resp
  674. }