• django manager


    django manager

    在语句Book.objects.all()中,objects是一个特殊的属性,需要通过它查询数据库。

    总之,模块manager是一个对象,Django模块通过它进行数据库查询。 每个Django模块至少有一个manager,你可以创建自定义manager以定制数据库访问。

    创建自定义manager: 1)增加额外的manager方法 2)修manager返回的初始QuerySet。

    1. 增加额外的Manager方法

    增加额外的manager方法是为模块添加表级功能的首选办法。

    例如,我们为Book模型定义了一个title_count()方法,它需要一个关键字,返回包含这个关键字的书的数量。 (这个例子有点牵强,不过它可以说明managers如何工作。)

    # models.py
    from django.db import models
    
    class BookManager(models.Manager):
    	def title_count(self, keyword):
    		return self.filter(title__icontains=keyword).count()
     
    class Book(models.Model):
    	title = models.CharField(max_length=100)
    	authors = models.ManyToManyField(Author)
    	publisher = models.ForeignKey(Publisher)
    	publication_date = models.DateField()
    	num_pages = models.IntegerField(blank=True, null=True)
    	objects = BookManager()   # 语法就是object=SomeManager
     
      def __unicode__(self):
        return self.title
    

    有了这个manager,我们现在可以这样做:

    >>> Book.objects.title_count('django')
    4
    >>> Book.objects.title_count('python')
    18
    

    为什么我们要添加一个title_count()方法呢?是为了将经常使用的查询进行封装,这样我们就不必重复编码了。
    修改初始Manager QuerySets

    manager的基本QuerySet返回系统中的所有对象。 例如, Book.objects.all() 返回数据库book中的所有书本。

    我们可以通过覆盖Manager.get_query_set()方法来重写manager的基本QuerySet。 get_query_set()按照你的要求返回一个QuerySet。

    这个例子也指出了其他有趣的技术: 在同一个模型中使用多个manager。 只要你愿意,你可以为你的模型添加多个manager()实例。 这是一个为模型添加通用滤器的简单方法。

    例如:

    class MaleManager(models.Manager):
      def get_query_set(self):
        return super(MaleManager, self).get_query_set().filter(sex='M')
     
    class FemaleManager(models.Manager):
      def get_query_set(self):
        return super(FemaleManager, self).get_query_set().filter(sex='F')
     
    class Person(models.Model):
      first_name = models.CharField(max_length=50)
      last_name = models.CharField(max_length=50)
      sex = models.CharField(max_length=1, choices=(('M', 'Male'), ('F', 'Female')))
      people = models.Manager()
      men = MaleManager()
      women = FemaleManager()
    

    这个例子允许你执行 Person.men.all() Person.women.all() Person.people.all() 查询,生成你想要的结果。

    如果你使用自定义的Manager对象,请注意,Django遇到的第一个Manager(以它在模型中被定义的位置为准)会有一个特殊状态。 Django将会把第一个Manager 定义为默认Manager ,Django的许多部分(但是不包括admin应用)将会明确地为模型使用这个manager。 结论是,你应该小心地选择你的默认manager。因为覆盖get_query_set() 了,你可能接受到一个无用的返回对像,你必须避免这种情况。

  • 相关阅读:
    JSON 在 IE 下不执行的问题
    一些UTF8编码问题
    如果你也想做一个Pinterest?
    关于apache虚拟机的NameVirtualHost错误
    如何玩转数据库设计
    mysql 导入数据时 max_allowed_packet 的问题
    几个练习题
    数组,for语句(补10.11)
    MySql数据库
    js基础(补10.10)
  • 原文地址:https://www.cnblogs.com/wangjiale1024/p/11391236.html
Copyright © 2020-2023  润新知