trans_conf_service.py 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. # -*- coding: utf-8 -*-
  2. # @Time : 2025/1/9
  3. # @Author : 魏志亮
  4. from datetime import datetime
  5. from service.common_connect import trans
  6. def update_timeout_trans_data():
  7. sql = """
  8. UPDATE data_transfer
  9. SET trans_sys_status = 2,err_info='运行超时失败',transfer_status=2
  10. WHERE
  11. TIMESTAMPDIFF(HOUR, transfer_start_time, NOW()) > 24
  12. AND trans_sys_status = 0
  13. """
  14. trans.execute(sql)
  15. def update_trans_status_running(id, save_db=True):
  16. if save_db:
  17. exec_sql = """
  18. update data_transfer set transfer_status = 0,trans_sys_status = 0 ,transfer_start_time = now(),err_info='',
  19. engine_count =0,time_granularity=0,transfer_finish_time=null,transfer_progress=0,
  20. data_min_time= null,data_max_time= null,transfer_data_count=null
  21. where id = %s
  22. """
  23. trans.execute(exec_sql, id)
  24. def update_archive_success(id, archive_path, save_db=True):
  25. if save_db:
  26. exec_sql = """
  27. update data_transfer set transfer_progress=70,archive_path = %s
  28. where id = %s
  29. """
  30. trans.execute(exec_sql, (archive_path, id))
  31. def update_trans_status_error(id, message="", save_db=True):
  32. if save_db:
  33. exec_sql = """
  34. update data_transfer set transfer_status = 2,trans_sys_status=2 ,err_info= %s,transfer_finish_time=now()
  35. where id = %s
  36. """
  37. message = message if len(message) <= 200 else message[0:200]
  38. trans.execute(exec_sql, (message, id))
  39. def update_trans_status_success(id, wind_count=0, time_granularity=0,
  40. min_date=datetime.now(),
  41. max_date=datetime.now(),
  42. total_count=0, save_db=True):
  43. if save_db:
  44. if min_date is not None:
  45. exec_sql = """
  46. update data_transfer set transfer_status = 1,trans_sys_status = 1,transfer_progress=100,err_info = '',
  47. engine_count =%s,time_granularity=%s,transfer_finish_time=now(),
  48. data_min_time= %s,data_max_time= %s,transfer_data_count=%s,is_high_priority=0
  49. where id = %s
  50. """
  51. trans.execute(exec_sql, (wind_count, time_granularity, min_date, max_date, total_count, id))
  52. else:
  53. exec_sql = """
  54. update data_transfer set transfer_status = 1,trans_sys_status = 1,transfer_progress = 100,err_info = '',
  55. engine_count =%s,time_granularity=%s,transfer_finish_time=now(),is_high_priority=0
  56. where id = %s
  57. """
  58. trans.execute(exec_sql, (wind_count, time_granularity, id))
  59. def update_trans_transfer_progress(id, transfer_progress=0, save_db=True):
  60. print(id, transfer_progress)
  61. if save_db:
  62. exec_sql = """
  63. update data_transfer set transfer_progress =%s where id = %s
  64. """
  65. trans.execute(exec_sql, (int(transfer_progress), id))
  66. def get_now_running_count():
  67. query_running_sql = """
  68. select count(1) as count from data_transfer where trans_sys_status = 0
  69. """
  70. data = trans.execute(query_running_sql)
  71. now_count = int(data[0]['count'])
  72. return now_count
  73. # 获取执行的数据
  74. def get_batch_exec_data() -> dict:
  75. query_next_exec_sql = """
  76. SELECT
  77. *
  78. FROM
  79. data_transfer t
  80. WHERE
  81. t.trans_sys_status in (-1,1,2) and t.transfer_status = -1
  82. AND t.read_dir != ''
  83. ORDER BY
  84. t.is_high_priority desc,
  85. t.update_time
  86. LIMIT 1
  87. """
  88. data = trans.execute(query_next_exec_sql)
  89. if type(data) == tuple:
  90. return None
  91. return data[0]
  92. def create_wave_table(table_name, save_db=True):
  93. if save_db:
  94. exec_sql = f"""
  95. CREATE TABLE `{table_name}` (
  96. `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',
  97. `wind_turbine_number` varchar(20) DEFAULT NULL COMMENT '风机编号',
  98. `wind_turbine_name` varchar(20) DEFAULT NULL COMMENT '原始风机编号',
  99. `time_stamp` datetime DEFAULT NULL COMMENT '时间',
  100. `rotational_speed` float DEFAULT NULL COMMENT '转速',
  101. `sampling_frequency` varchar(50) DEFAULT NULL COMMENT '采样频率',
  102. `mesure_point_name` varchar(100) DEFAULT NULL COMMENT '测点名称',
  103. `type` int(11) DEFAULT '-1' COMMENT '-1:不存在 0:角度 1:速度 2:加速度 3:位移,默认 -1',
  104. `mesure_data` longtext COMMENT '测点数据',
  105. PRIMARY KEY (`id`),
  106. KEY `wind_turbine_number` (`wind_turbine_number`),
  107. KEY `time_stamp` (`time_stamp`),
  108. KEY `mesure_point_name` (`mesure_point_name`)
  109. ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4
  110. """
  111. trans.execute(exec_sql)