自定义模型管理器
每个模型类默认都有一个 objects 类属性,可以把它叫 模型管理器。它由django自动生成,类型为
django.db.models.manager.Manager
可以在模型类中自定义模型管理器,自定义后, Django将不再生成默认的 objects。(模型类可以自定义多个管理器)
例如:
class Department(models.Model): # 自定义模型管理器 manager = models.Manager()
调用 Department.objects会抛出AttributeError异常,而 Department.manager.all()会返回一个包含所有Department对象的列表。
两种情况需要自定义管理器
修改管理器返回的原始查询集
需求: 调用
Department.manager.all()
返回的是2009年之后成立的部门管理器类中添加额外的方法,帮我们操作模型类对应的数据表
需求: 在管理器类中,定义一个创建部门的方法
一、自定义模型管理器
class DepartmentManager(Manager):
# 修改管理器返回的原始查询集
def all(self):
"""重写all方法:只返回2009年之后成立的部门"""
return super().all().filter(create_date__gte=date(2009,1,1))
# 在模型管理器中封装增删查的方法
def create_dep(self, name, create_date):
"""新增一个部门"""
dep = Department()
dep.name = name
dep.create_date = create_date
dep.save()
return dep # 返回新增后的员工对象
二、在模型类中使用自定义的模型管理器
class Department(models.Model):
"""部门类"""
...
# 自定义模型管理器(默认的objects就不会再生成)
objects = DepartmentManager()
三、在视图函数中,使用自定义的模型管理器中的方法
def add_dep(request):
"""新增部门"""
# d = Department()
# d.name = '财务部'
# d.create_date = date(2018, 1, 1)
# d.save()
# 调用自定义的模型管理器,新增一个部门
Department.objects.create_dep('财务部', date(2018, 1, 1))
# 返回的不再是所有的部门,而是2009年之后成立的部门
# Department.objects.all()
return redirect('/show_deps')
元选项(Meta)
一、修改表名:
Django默认生成的表名:
应用名小写_模型类名小写
可以通过在模型类中定义Meta类来修改表名:
class Department(models.Model): """部门类""" name = models.CharField(max_length=20) class Meta(object): """指定表名""" db_table = "department"
重新生成迁移文件,并迁移生成表,查看表名是否有修改
二、 修改模型类在管理后台的显示名称
class Meta:
# 定义表名
db_table = 'department'
# 定义在管理后台显示的名称
verbose_name = '部门'
# 指定复数时的名称(去除复数的s)
verbose_name_plural = verbose_name