Django的ORM框架相当强大,只需要在每个app的models.py文件中创建Class即可,每个字段就是一个类的属性
示例:
from django.db import models
from django.contrib.auth.models import AbstractUser
# 用户信息模型
class UserProfile(AbstractUser):
mobile = models.CharField(verbose_name=u"手机号码", max_length=20, null=True, blank=True)
gender = models.CharField(
verbose_name=u"性别", choices=(("male", u"男"), ("female", u"女")), default="male", max_length=6)
real_name = models.CharField(verbose_name=u"真实姓名", max_length=50, null=True, blank=True)
city = models.CharField(verbose_name=u"城市", max_length=20, null=True, blank=True)
introduction = models.TextField(verbose_name=u"个人介绍", null=True, blank=True)
class Meta:
verbose_name = u"用户信息"
verbose_name_plural = verbose_name
def __unicode__(self):
return self.username
modes.py中的类需要继承django.db中的models.Model,这个例子中继承了AbstractUser,这是django中用户类的原型,因为我要使用自己的用户模型,所以继承了它。在默认的用户模型中已经有了用户名、密码及邮箱,所以这里并没有设置。
数据库中的数据类型在django中表现为不同的Field,常用的有CharField、TextField、FileField等。
Fields共有的属性
这些Field共有的属性有null、blank、unique等,当然大部分Field还可以设置为主键(只能设置一个)
null属性设置为True时,数据库中表现为字段可以为空;而blank设置为True时即表示这个属性在实例化类时必须进行赋值。
unique属性:顾名思义,设置为True后该字段不能重复
有时候需要通过多个字段判断唯一性,可以在Meta中设置:
unique_together = ("value_1", "value_2")
primary_key属性,主键,不设置也可以,不设置的话会自动生成自增的字段id
verbose_name,字段的别名,这个是在后台显示的
Meta
Meta中设置这个数据表的属性,verbose_name表的别名,verbose_name_plural表的别名的复数形式。
当然如果你不希望在后台看到“用户信息s”这种神奇的东西的话,就将上述两个属性设置成一样即可:
class Meta:
verbose_name = u"个人信息"
verbose_name_plural = verbose_name
unicode(python3中使用str)方法,设置实例的别名
CharField
CharField即对应mysql中的varchar,在这个Field中,max_length是必须设置的。
FileField & ImageField
这俩差不多是一样的,但是ImageField会验证文件类型是否为有效的图片。此外,ImageField中,必须设置max_length,而FileField中max_length有默认值100。在数据库中,并不存放文件本身,而是存放着文件的相对路径。
因此,通常都会设置upload_to属性,即上传的文件保存在哪,文件将会被保存在设置的MEDIA_ROOT中,如:
upload_to='user/'
当然也可以使用自定义的动态的上传方法
def upload_for_file(instance, filename):
return '/'.join(['233', '666', user.username, filename])
file = models.FileField(null=True, blank=True, upload_to=upload_for_file)
通常,修改文件并不会删除原先的文件,可以在修改操作时先进行删除
user.file.delete(save=False)
当然这样做很麻烦,也不便维护,所以我们可以重载Class中的save方法:
def save(self, *args, **kwargs):
# delete old file when replacing by updating the file
try:
this = AttendedPerson.objects.get(id=self.id)
if this.file != self.file:
this.file.delete(save=False)
except Exception as e:
pass
super(AttendedPerson, self).save(*args, **kwargs)
此外,还有要注意的一点就是:删除实例(数据库中的一行)时,并不会删除文件。
我选择手动删除orz