Django框架自定义模型管理器与元选项用法分析

这篇文章主要介绍了Django框架自定义模型管理器与元选项用法,结合实例形式分析了自定义模型管理器与元选项的功能、用法及相关操作注意事项,需要的朋友可以参考下

本文实例讲述了Django框架自定义模型管理器与元选项用法。分享给大家供大家参考,具体如下:

自定义模型管理器

每个模型类默认都有一个 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 

希望本文所述对大家基于Django框架的Python程序设计有所帮助。

以上就是Django框架自定义模型管理器与元选项用法分析的详细内容,更多请关注0133技术站其它相关文章!

赞(0) 打赏
未经允许不得转载:0133技术站首页 » python