本节介绍Django模型的属性和方法,以及如何重写之前定义的模型方法等内容。
3.5.1 模型属性
Django模型中最重要的属性就是Manager,它是Django模型和数据库查询操作之间的接口,并且被用作从数据库当中获取实例的途径。如果Django模型中没有指定自定义的Manager,则默认名称就是“objects”。
另外,Manager只能通过模型类来访问,不能通过模型实例来访问。
3.5.2 模型方法
在Django模型中添加自定义方法,会给对象提供自定义的“行级”操作能力;与之对应的是Manager的方法,其目的在于提供“表级”的操作。模型方法应该在某个对象实例上生效,这是一个将相关逻辑代码放在模型上的技巧。
关于模型方法的使用,示例代码如下:
【代码3-12】
- 01 from django.db import models
- 02
- 03 class PersonAge(models.Model):
- 04 name = models.CharField(max_length=32)
- 05 age = models.CharField(max_length=8)
- 06
- 07 def person_age_status(self):
- 08 "Returns the person's age status."
- 09 if self.age < 1:
- 10 return "Baby"
- 11 elif self.age < 3:
- 12 return "Toddler"
- 13 elif self.age < 6:
- 14 return "Preschooler"
- 15 elif self.age < 12:
- 16 return "School-Children"
- 17 elif self.age < 18:
- 18 return "Teenager"
- 19 elif self.age < 40:
- 20 return "Youth"
- 21 elif self.age < 60:
- 22 return "Middle-Age"
- 23 else:
- 24 return "Old-Age"
- 25
- 26 @property
- 27 def person_info(self):
- 28 "Returns the person's info."
- 29 return '%s %s' % (self.name, self.age)
- 30 #...
- 31 pass
【代码分析】
在第03行代码中,定义了一个描述人的年龄段的类PersonAge。
在第07~24行代码中,定义了PersonAge类的模型方法person_age_status(),返回具体年龄段的信息。
在第26~29行代码中,定义了PersonAge类的属性方法person_info(),返回个人信息。
3.5.3 重写之前定义的模型方法
Django模型中还有一个关于模型方法的集合,其中包含了一些可能是自定义的数据库行为,比如save()方法和delete()方法就是两个最有可能定制的方法。同时,设计人员可以重写这些方法(或其他模型方法)以更改方法的行为。
有一个非常典型的重写内置方法的场景,就是打算在保存对象时额外做一些事。关于重写save()方法的示例代码如下:
【代码3-13】
- 01 from django.db import models
- 02
- 03 class Blog(models.Model):
- 04 name = models.CharField(max_length=100)
- 05 tagline = models.TextField()
- 06
- 07 def save(self, *args, **kwargs):
- 08 do_something()
- 09 super().save(*args, **kwargs) # Call the "real" save() method.
- 10 do_something_else()
- 11 #...
- 12 pass
【代码分析】
在第03行代码中,定义了一个描述博客的类Blog。
在第07~10行代码中,重写了save()方法,具体说明如下:
另外,还可以重写 save()方法来阻止该方法的执行,示例代码如下:
【代码3-14】
- 01 from django.db import models
- 02
- 03 class Blog(models.Model):
- 04 name = models.CharField(max_length=100)
- 05 tagline = models.TextField()
- 06
- 07 def save(self, *args, **kwargs):
- 08 if self.name == "King's blog":
- 09 return # King永远不应该有自己的博客
- 10 else:
- 11 super().save(*args, **kwargs) # 调用原生的save()方法
- 12 #...
- 13 pass
【代码分析】
在第03行代码中,定义了一个描述博客的类Blog。
在第07~11行代码中,重写了save()方法,具体说明如下:
Django模型会不时地扩展模型内置方法的功能,也会添加新参数。假如设计人员在重写的方法中使用了*args和**kwargs参数,则必须确保重写方法能够接收这些新添加的参数。
本文节选自《Django 5企业级Web应用开发实战(视频教学版)》,获出版社和作者授权发布。