问题描述
如果我在商店中添加了一些书籍,那么我如何获得商店中所选书籍的total_price?
信号不起作用,它们不是calculating anything。我想计算selected books。提交表格后,我的总价为still (0)。
商店
from django.db import models
class Book(models.Model):
name = models.CharField(max_length=100)
price = models.IntegerField(default=0)
class Store(models.Model):
keeper = models.ForeignKey(User,on_delete=models.SET_NULL,null=True)
books = models.ManyToManyField(Book)
total_price = models.IntegerField(default=0)
signals.py
from django.db.models import Sum
from django.db.models.signals import pre_save
from django.dispatch import receiver
from .models import Store
from .models import Book
@receiver(pre_save,sender=Store)
def save_total_price(sender,instance,**kwargs):
instance.total = Book.objects.all().aggregate(Sum("price"))["price__sum"]
apps.py
from django.apps import AppConfig
class ReportConfig(AppConfig):
name = 'report'
def ready(self):
import report.signals
初始化 .py
default_app_config = "report.apps.ReportAppConfig"
解决方法
您可以为此使用信号。
在应用程序中创建文件singals.py
。
@receiver(pre_save,sender=Store)
def save_total_price(sender,instance,**kwargs):
instance.total = Book.objects.all().aggregate(Sum("price"))["price__sum"]
按以下方式在App的Config中连接信号:
# app.py
class WhateverAppConfig(AppConfig):
name = "{app_path}"
def ready(self):
import {app_path}.signals
现在在应用程序的__init__.py
中指向配置,如下所示:
default_app_config = "{app_path}.apps.WhateverAppConfig"
其他解决方案可能包括保存该信息的缓存变量(我认为这是更好的方法)。
,您需要使用m2m_changed
在信号中定义一个函数,如果您要将total_price保存到数据库中,我认为这是更好的方法。感谢大家的帮助。这段代码对我来说很好。 :)
def save_total_price(sender,action,*args,**kwargs):
if action in ['post_add','post_remove','post_clear']:
books = instance.books.all()
instance.total_price = 0
for book in books:
instance.total_price += book.price
instance.save()
m2m_changed.connect(save_total_price,sender=Patient.books.through)