[英]How to count objects from database filtered by a choice field in django?
[英]Django count objects field
我需要创建一个字段来计算每个图书馆的注册图书数量。
每本书都通过 ForeighKey 与图书馆相关联
如果我注册或删除一本书,它应该会在与您自己的图书馆相关的“book_count”字段中自动更新。
图书馆/模型.py
from django.db import models
class Libraries(models.Model):
name = models.CharField(max_length=50)
book_count = models.IntegerField(default=0)
def __str__(self):
return self.name
书籍/模型.py
from django.db import models
from libraries.models import Libraries
class Books(models.Model):
library = models.ForeignKey(Libraries, on_delete=models.DO_NOTHING, blank=True, null=True)
book = models.CharField(max_length=200, null=True, blank=True)
def __str__(self):
return self.book
如何在每个图书馆的模型中创建这个简单的图书柜台?
给定以下应用程序
$ tree -L 2
.
├── db.sqlite3
├── libraryapp
│ ├── __init__.py
│ ├── __pycache__
│ ├── admin.py
│ ├── migrations
│ ├── models.py
│ ├── settings.py
│ ├── urls.py
│ └── wsgi.py
└── manage.py
和你的模型(我做了一些重构)
$ cat libraryapp/models.py
from django.db import models
class Library(models.Model):
name = models.CharField(max_length=50)
book_count = models.IntegerField(default=0)
def __str__(self):
return self.name
class Book(models.Model):
name = models.CharField(max_length=200, null=True, blank=True)
library = models.ForeignKey(Library, on_delete=models.DO_NOTHING, blank=True, null=True)
def __str__(self):
return self.name
def save(self):
super().save()
self.update_book_count()
def delete(self):
super().delete()
self.update_book_count()
def update_book_count(self):
if self.library:
self.library.book_count = self.library.book_set.count()
self.library.save()
您可以按如下方式获取某个图书馆的图书数量:
$ python3 manage.py shell
>>> from libraryapp.models import Book, Library
>>> library = Library.objects.first()
>>> library.book_count
1
请注意,这假定更新图书馆图书数量的唯一方法是通过添加或删除图书。
我使用 Signals 得到了它。
@receiver(post_save, sender=Book)
def add_book_count(instance, created, **kwargs):
if created:
instance.library.book_count += 1
instance.library.save()
@receiver(post_delete, sender=Book)
def rem_statement_count(instance, **kwargs):
instance.library.book_count -= 1
instance.library.save()
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.