美文网首页
Models Manager

Models Manager

作者: dchang | 来源:发表于2018-08-16 07:54 被阅读16次
  • 修改objects为自定义
from django.db import models
class Person(models.Model):
    #...
    people = models.Manager()
通过以上代码之后
Person.objects 会产生一个 AttributeError 异常, 但是Person.people.all() 将会提供一个所有的Person的列表.
  • 自定义Manager,主要用于增加方法或者修改返回值
from django.db import models

class PollManager(models.Manager):
    def with_counts(self):
        from django.db import connection
        with connection.cursor() as cursor:
            cursor.execute("""
                SELECT p.id, p.question, p.poll_date, COUNT(*)
                FROM polls_opinionpoll p, polls_response r
                WHERE p.id = r.poll_id
                GROUP BY p.id, p.question, p.poll_date
                ORDER BY p.poll_date DESC""")
            result_list = []
            for row in cursor.fetchall():
                p = self.model(id=row[0], question=row[1], poll_date=row[2])
                p.num_responses = row[3]
                result_list.append(p)
        return result_list

class OpinionPoll(models.Model):
    question = models.CharField(max_length=200)
    poll_date = models.DateField()
    objects = PollManager()

class Response(models.Model):
    poll = models.ForeignKey(OpinionPoll, on_delete=models.CASCADE)
    person_name = models.CharField(max_length=50)
    response = models.TextField()

以上示例中使用 OpinionPoll.objects.with_counts() 则会返回一个OpinionPoll objects列表包含 num_responses 属性
  • 修改manager初始的QuerrySet
Manager 的基础QS返回的是所有的成员

from django.db import models
class Book(models.Model):
    title = models.CharField(max_length=100)
    author = models.CharField(max_length=50)
Book.objects.all() 将会返回数据库中所有的书

你可以复写Manager的基础QS,通过集成类,复写Manager.get_queryset() 方法来返回一个QS但是包含其他所需要的属性

下属例子中Book有2个manager,其中一个为最原始的manager,返回的是所有的书本信息列表,
然后添加一个DahlBookManager, 用于过滤信息,这样的话用户在使用的时候可以使用
Models.objetcs 或者 Models.OTHER_MANAGER来调用不同的manager的方法来返回特定的信息。

# First, define the Manager subclass.
class DahlBookManager(models.Manager):
    def get_queryset(self):
        return super().get_queryset().filter(author='Roald Dahl')

# Then hook it into the Book model explicitly.
class Book(models.Model):
    title = models.CharField(max_length=100)
    author = models.CharField(max_length=50)
    objects = models.Manager() 
    # The default manager. 调用的时候就是Book.objects .all()
    dahl_objects = DahlBookManager() 
    # The Dahl-specific manager., 调用的时候就是Book.dahl_objects .all()
  • Default managers (django的默认manager)
Model._default_manager
如果一个models中有多个manager,这样系统会默认按代码的顺序把第一个
Manager设置为默认的Manager,所有默认方法都会使用该默认models的manager去获取数据,
使用 Meta.default_manager_name 来指定默认的manager
  • base_manager

相关文章

网友评论

      本文标题:Models Manager

      本文链接:https://www.haomeiwen.com/subject/hblibftx.html