Django建站笔记(二)——ORM

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

你可能感兴趣的:(Django建站笔记(二)——ORM)