AutoField – Django模型
根据文档,AutoField是一个IntegerField,它根据可用的ID自动递增。人们通常不需要直接使用它,因为如果你不指定,一个主键字段会自动添加到你的模型中。
默认情况下,Django给每个模型提供以下字段。
id = models.AutoField(primary_key=True, **options)
这是一个自动递增的主键。即使模型没有任何字段,也会创建一个名为id的默认字段。
Django模型自动字段说明
用一个例子说明AutoField的情况。考虑一个名为geeksforgeeks的项目,它有一个名为geeks的应用程序。
在geeks应用程序的models.py文件中输入以下代码。
from django.db import models
from django.db.models import Model
# Create your models here.
class GeeksModel(Model):
pass
在INSTALLED_APPS中增加geek的应用程序。
# Application definition
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'geeks',
]
现在,当我们从终端运行makemigrations命令时。
Python manage.py makemigrations
在geeks目录下将创建一个名为migrations的新文件夹,其中有一个名为0001_initial.py的文件。
# Generated by Django 2.2.5 on 2019-09-25 06:00
from django.db import migrations, models
class Migration(migrations.Migration):
initial = True
dependencies = [
]
operations = [
migrations.CreateModel(
name ='GeeksModel',
fields =[
('id',
models.AutoField(auto_created = True,
primary_key = True,
serialize = False,
verbose_name ='ID'
)),
],
),
]
因此,当你在项目上运行makemigrations时,默认创建了一个id AutoField,它在该模型的每个实例上都会自动递增。它是为名为GeeksModel的模型创建的表的一个主键。
如果我们从管理服务器上创建这个空模型的对象,我们可以看到id字段在每个创建的实例上自动递增。
字段选项
字段选项是给每个字段的参数,用于应用一些约束或赋予一个特定的字段以特定的特征。例如,给AutoField添加参数primary_key=True将使它成为关系数据库中该表的主键。
以下是一个自动场可以使用的选项和属性。
字段选项 | 描述 |
---|---|
Null | 如果为真,Django将在数据库中把空值存储为NULL。默认为假。 |
Blank | 如果为真,该字段允许为空白。默认为 “假”。 |
db_column | 这个字段要使用的数据库列的名称。如果没有给出,Django将使用该字段的名称。 |
Default | 该字段的默认值。这可以是一个值或一个可调用对象。如果是可调用的,它将在每次创建新对象时被调用。 |
help_text | 额外的 “帮助 “文本将显示在表单部件上。即使你的字段不在表单中使用,它对文档也很有用。 |
primary_key | 如果为真,这个字段就是模型的主键。 |
editable | 如果是假的,该字段将不会显示在管理员或任何其他 ModelForm 中。它们在模型验证过程中也会被跳过。默认为True。 |
error_messages | error_messages参数让你覆盖字段将产生的默认信息。传入一个字典,其键值与你想覆盖的错误信息相匹配。 |
help_text | 额外的 “帮助 “文本将显示在表单部件上。即使你的字段不在表单中使用,它对文档也很有用。 |
verbose_name | 该字段的一个人类可读的名字。如果没有给出verbose名称,Django会使用字段的属性名称自动创建它,并将下划线转换为空格。 |
validators | 对这个字段要运行的验证器列表。更多信息请参见验证器文档。 |
Unique | 如果为真,这个字段在整个表中必须是唯一的。 |