feat: 按个选入消耗时统计mlog数据优化

This commit is contained in:
caoqianming 2025-07-07 11:08:29 +08:00
parent 28acc48768
commit 45647d2149
2 changed files with 12 additions and 3 deletions

View File

@ -506,10 +506,10 @@ class Mlogbw(BaseModel):
if mlogb.material_in:
mlogb.count_use = count
mlogb.save(update_fields=["count_use"])
mlogb.cal_count_notok(cal_mlog=True)
elif mlogb.material_out:
mlogb.count_real = count
count_notok = 0
count_notok_full = 0
tqs = Mlogbw.objects.filter(mlogb=mlogb, ftest__is_ok=False)
tqs_a = Mlogbw.objects.filter(mlogb=mlogb, ftest__is_ok=False).values("ftest__defect_main").annotate(xcount=Count('id'))
defects = {defect.id: defect for defect in Defect.objects.filter(id__in=tqs.values_list("ftest__defect_main", flat=True))}
@ -520,11 +520,13 @@ class Mlogbw(BaseModel):
md.save()
md_ids.append(md.id)
count_notok += t["xcount"]
if defects[t["ftest__defect_main"]].okcate != 10:
count_notok_full += t["xcount"]
MlogbDefect.objects.filter(mlogb=mlogb).exclude(id__in=md_ids).delete()
mlogb.count_notok = count_notok
mlogb.count_ok = count - mlogb.count_notok
mlogb.count_ok_full = count - count_notok_full
mlogb.save()
mlogb.cal_count_notok(cal_mlog=True)
class Handover(CommonADModel):
"""

View File

@ -808,12 +808,13 @@ class MlogbwViewSet(CustomModelViewSet):
@transaction.atomic
def perform_create(self, serializer):
ins:Mlogbw = serializer.save()
mlog = ins.mlogb.mlog
if isinstance(ins, list):
insx = ins
else:
insx = [ins]
for ins in insx:
route:Route = ins.mlogb.mlog.route
route:Route = ins.mlogb.route
mlogb:Mlogb = ins.mlogb
Mlogbw.cal_count_notok(mlogb)
# 如果是输入且输出追踪到个,需同步创建
@ -859,11 +860,14 @@ class MlogbwViewSet(CustomModelViewSet):
for i in range(route.div_number):
Mlogbw.objects.get_or_create(mlogb=mlogb, number=f'{ins.number}-{i+1}', defaults={"mlogbw_from": ins})
Mlogbw.cal_count_notok(mlogb)
mlog.cal_mlog_count_from_mlogb()
@transaction.atomic
def perform_update(self, serializer):
mlogbw = serializer.save()
Mlogbw.cal_count_notok(mlogbw.mlogb)
mlog = mlogbw.mlogb.mlog
mlog.cal_mlog_count_from_mlogb()
@transaction.atomic
def perform_destroy(self, instance:Mlogbw):
@ -891,6 +895,9 @@ class MlogbwViewSet(CustomModelViewSet):
mlogb_qs = Mlogb.objects.filter(id__in=mlogbIds)
for mlogb in mlogb_qs:
Mlogbw.cal_count_notok(mlogb)
mlog = mlogb.mlog
mlog.cal_mlog_count_from_mlogb()
class MlogUserViewSet(BulkCreateModelMixin, ListModelMixin, DestroyModelMixin, CustomGenericViewSet):
perms_map = {"get": "*", "post": "mlog.update", "delete": "mlog.update"}