DeviceGroupController.py 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  1. # @Author : Rocky
  2. # @File : DeviceGroupController.py
  3. # @Time : 2025/1/22 9:51
  4. from django.db import transaction
  5. from django.db.models import Count
  6. from django.db.models import Q
  7. from django.views import View
  8. from Model.models import DeviceGroup, Device_Info
  9. from Service.CommonService import CommonService
  10. class DeviceGroupView(View):
  11. def get(self, request, *args, **kwargs):
  12. request.encoding = 'utf-8'
  13. operation = kwargs.get('operation')
  14. return self.validation(request.GET, request, operation)
  15. def post(self, request, *args, **kwargs):
  16. request.encoding = 'utf-8'
  17. operation = kwargs.get('operation')
  18. return self.validation(request.POST, request, operation)
  19. def validation(self, request_dict, request, operation):
  20. token_code, user_id, response = CommonService.verify_token_get_user_id(request_dict, request)
  21. if token_code != 0:
  22. return response.json(token_code)
  23. if operation == 'queryGroupQuantity': # 查询分组数量
  24. return self.query_group_quantity(request_dict, user_id, response)
  25. elif operation == 'queryGroupDevice': # 查询分组设备
  26. return self.query_group_device(request_dict, user_id, response)
  27. elif operation == 'queryOtherGroupDevice': # 查询其他分组设备
  28. return self.query_other_group_device(request_dict, user_id, response)
  29. elif operation == 'creat': # 创建分组
  30. return self.creat(request_dict, user_id, response)
  31. elif operation == 'update': # 重命名分组
  32. return self.update(request_dict, user_id, response)
  33. elif operation == 'delete': # 删除分组
  34. return self.delete(request_dict, user_id, response)
  35. elif operation == 'transferGroup': # 转移分组
  36. return self.transfer_group(request_dict, user_id, response)
  37. else:
  38. return response.json(414)
  39. @staticmethod
  40. def query_group_quantity(request_dict, user_id, response):
  41. """
  42. 查询分组数量(优化版:减少数据库查询次数,提升性能)
  43. @param request_dict: 请求参数
  44. @param user_id: 用户ID
  45. @param response: 响应对象
  46. @return: 包含分组信息和设备总数的响应
  47. """
  48. # 1. 一次查询获取所有分组ID和名称(仅1次数据库查询)
  49. device_groups = list(DeviceGroup.objects.filter(user_id=user_id).values('id', 'group_name'))
  50. if not device_groups:
  51. return response.json(0, {'total': 0, 'device_groups': []})
  52. # 2. 提取所有分组ID,批量查询设备数量(仅1次数据库查询)
  53. group_ids = [group['id'] for group in device_groups]
  54. device_counts = dict(
  55. Device_Info.objects.filter(device_group_id__in=group_ids)
  56. .values('device_group_id')
  57. .annotate(count=Count('id')) # 聚合计算每个分组的设备数
  58. .values_list('device_group_id', 'count') # 转换为(id, count)格式
  59. )
  60. # 3. 内存中组装数据(无额外数据库查询)
  61. device_total = 0
  62. for group in device_groups:
  63. # 从字典中获取数量,默认0(避免不存在的分组ID报错)
  64. count = device_counts.get(group['id'], 0)
  65. group['device_quantity'] = count
  66. device_total += count
  67. return response.json(0, {
  68. 'total': device_total,
  69. 'device_groups': device_groups
  70. })
  71. @staticmethod
  72. def query_group_device(request_dict, user_id, response):
  73. """
  74. 查询分组设备
  75. @param request_dict:
  76. @param user_id:
  77. @param response:
  78. @return: res
  79. """
  80. device_group_id = request_dict.get('device_group_id', None)
  81. if not device_group_id:
  82. return response.json(444)
  83. device_info_qs = Device_Info.objects.filter(device_group_id=device_group_id).values('NickName', 'Type')
  84. if not device_info_qs.exists():
  85. return response.json(0, [])
  86. res = list(device_info_qs)
  87. return response.json(0, res)
  88. @staticmethod
  89. def query_other_group_device(request_dict, user_id, response):
  90. """
  91. 查询其他分组设备
  92. @param request_dict:
  93. @param user_id:
  94. @param response:
  95. @return: res
  96. """
  97. device_group_id = request_dict.get('device_group_id', None)
  98. if not device_group_id:
  99. return response.json(444)
  100. try:
  101. res = []
  102. # 查询全部设备
  103. if device_group_id != '0':
  104. device_info_qs = Device_Info.objects.filter(~Q(device_group_id=device_group_id), userID=user_id). \
  105. values('id', 'NickName', 'Type')
  106. if device_info_qs.exists():
  107. data = {
  108. 'id': 0,
  109. 'group_name': 'all'
  110. }
  111. device_info_list = []
  112. for device_info in device_info_qs:
  113. device_info_list.append(device_info)
  114. data['device_info_list'] = device_info_list
  115. res.append(data)
  116. # 查询设备数量不为0的其他分组
  117. device_group_qs = DeviceGroup.objects.filter(~Q(id=device_group_id), user_id=user_id). \
  118. values('id', 'group_name')
  119. if device_group_qs.exists():
  120. # 查询各组的设备id和昵称
  121. for device_group in device_group_qs:
  122. device_info_list = []
  123. device_info_qs = Device_Info.objects.filter(device_group_id=device_group['id']). \
  124. values('id', 'NickName', 'Type')
  125. for device_info in device_info_qs:
  126. device_info_list.append(device_info)
  127. device_group['device_info_list'] = device_info_list
  128. res.append(device_group)
  129. return response.json(0, res)
  130. except Exception as e:
  131. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  132. @staticmethod
  133. def creat(request_dict, user_id, response):
  134. """
  135. 创建分组
  136. @param request_dict:
  137. @param user_id:
  138. @param response:
  139. @return: res
  140. """
  141. group_name = request_dict.get('group_name', None)
  142. if not group_name:
  143. return response.json(444)
  144. # 该用户已存在该组名的分组
  145. device_group_qs = DeviceGroup.objects.filter(user_id=user_id, group_name=group_name)
  146. if device_group_qs.exists():
  147. return response.json(174)
  148. DeviceGroup.objects.create(user_id=user_id, group_name=group_name)
  149. return response.json(0)
  150. @staticmethod
  151. def update(request_dict, user_id, response):
  152. """
  153. 重命名分组
  154. @param request_dict:
  155. @param user_id:
  156. @param response:
  157. @return: res
  158. """
  159. device_group_id = request_dict.get('device_group_id', None)
  160. group_name = request_dict.get('group_name', None)
  161. if not all([device_group_id, group_name]):
  162. return response.json(444)
  163. # 该用户已存在该组名的分组
  164. device_group_qs = DeviceGroup.objects.filter(user_id=user_id, group_name=group_name)
  165. if device_group_qs.exists():
  166. return response.json(174)
  167. DeviceGroup.objects.filter(id=device_group_id).update(group_name=group_name)
  168. return response.json(0)
  169. @staticmethod
  170. def delete(request_dict, user_id, response):
  171. """
  172. 删除分组
  173. @param request_dict:
  174. @param user_id:
  175. @param response:
  176. @return: res
  177. """
  178. device_group_id = request_dict.get('device_group_id', None)
  179. if not device_group_id:
  180. return response.json(444)
  181. try:
  182. device_group_id = int(device_group_id)
  183. with transaction.atomic():
  184. # 删除设备分组数据,重置设备信息表的分组id
  185. DeviceGroup.objects.filter(id=device_group_id).delete()
  186. Device_Info.objects.filter(device_group_id=device_group_id).update(device_group_id=0)
  187. return response.json(0)
  188. except Exception as e:
  189. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  190. @staticmethod
  191. def transfer_group(request_dict, user_id, response):
  192. """
  193. 转移分组
  194. @param request_dict:
  195. @param user_id:
  196. @param response:
  197. @return: res
  198. """
  199. device_group_id = request_dict.get('device_group_id', None)
  200. device_id_list = request_dict.get('device_id_list', None)
  201. if not all([device_group_id, device_id_list]):
  202. return response.json(444)
  203. try:
  204. device_group_id = int(device_group_id)
  205. device_id_list = device_id_list.split(',')
  206. # 更新设备信息表的分组id
  207. Device_Info.objects.filter(id__in=device_id_list).update(device_group_id=device_group_id)
  208. return response.json(0)
  209. except Exception as e:
  210. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))