# 优化获取device_name 性能
This commit is contained in:
parent
39307f3fe8
commit
a7da7e4b5f
|
@ -1,7 +1,5 @@
|
||||||
import pytz
|
|
||||||
from django.db.models import Q
|
from django.db.models import Q
|
||||||
from datetime import datetime, time
|
from django.core.cache import cache
|
||||||
from django.db.models import Sum
|
|
||||||
from rest_framework import serializers
|
from rest_framework import serializers
|
||||||
from counter.models import DeviceCount, DeviceInfo
|
from counter.models import DeviceCount, DeviceInfo
|
||||||
from mosquito.models import DeviceInfo as CelexDeviceInfo
|
from mosquito.models import DeviceInfo as CelexDeviceInfo
|
||||||
|
@ -42,10 +40,16 @@ class DeviceCountSerializer(serializers.ModelSerializer):
|
||||||
return obj.data_time.strftime('%Y-%m-%d %H:%M:%S')
|
return obj.data_time.strftime('%Y-%m-%d %H:%M:%S')
|
||||||
|
|
||||||
def get_device_name(self, obj):
|
def get_device_name(self, obj):
|
||||||
qs = CelexDeviceInfo.objects.filter(device_id=obj.device_id)
|
device_id = obj.device_id
|
||||||
|
cache_content = cache.get(device_id)
|
||||||
|
if cache_content:
|
||||||
|
return cache_content
|
||||||
|
qs = CelexDeviceInfo.objects.filter(device_id=device_id)
|
||||||
if qs.count() > 0:
|
if qs.count() > 0:
|
||||||
device = qs[0]
|
device = qs[0]
|
||||||
return device.device_name
|
device_name = device.device_name
|
||||||
|
cache.set(device_id, device_name, 60 * 60 * 24)
|
||||||
|
return device_name
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,7 @@ class RoleMixin(object):
|
||||||
class DeviceListMixin(object):
|
class DeviceListMixin(object):
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def get_device_list():
|
def get_device_list():
|
||||||
if cache.has_key('device_list'):
|
if cache.get('device_list'):
|
||||||
device_list = cache.get('device_list')
|
device_list = cache.get('device_list')
|
||||||
else:
|
else:
|
||||||
device_list = DeviceInfo.objects.get_queryset().order_by('-online')
|
device_list = DeviceInfo.objects.get_queryset().order_by('-online')
|
||||||
|
|
Loading…
Reference in New Issue