在 Django 中,模型是一个类,用于包含基本字段和方法。每个模型类映射到数据库中的单个表。

Django Model 是django.db.models.Model的子类,模型类的每个字段代表一个数据库字段(列)。

Django 为我们提供了一个数据库抽象 API,它允许我们从映射表中创建、检索、更新和删除记录。

模型在Models.py文件中定义。该文件可以包含多个模型。

让我们看一个例子,我们正在创建一个模型Employee,它有两个字段first_namelast_name

from django.db import models  
  
class Employee(models.Model):  
    first_name = models.CharField(max_length=30)  
    last_name = models.CharField(max_length=30)  

First_name和Last_name字段被指定为类属性,每个属性映射到一个数据库列。

该模型将在数据库中创建一个表,如下所示。

CREATE TABLE appname_employee (  
    "id" INT NOT NULL PRIMARY KEY,  
    "first_name" varchar(30) NOT NULL,  
    "last_name" varchar(30) NOT NULL  
);  

创建的表包含一个自动创建的id 字段。表的名称是应用程序名称和型号名称的组合,可以进一步更改。

注册/使用模型

创建模型后,将模型注册到settings.py内的INSTALLED_APPS中

例如,

INSTALLED_APPS = [  
    #...  
    'appname',  
    #...  
]  

Django 模型字段

Model 类中定义的字段是映射表的列名。字段名称不应该是 python 保留字,例如 clean、save 或 delete 等。

Django 提供了各种内置字段类型。

Field NameClassParticular
AutoFieldclass AutoField(**options)它是一个自动递增的 IntegerField。
BigAutoFieldclass BigAutoField(**options)它是一个 64 位整数,与 AutoField 非常相似,只不过它保证适合从 1 到 9223372036854775807 的数字。
BigIntegerFieldclass BigIntegerField(**options)它是一个 64 位整数,与 IntegerField 非常相似,只不过它保证适合从 -9223372036854775808 到 9223372036854775807 的数字。
BinaryFieldclass BinaryField(**options)存储原始二进制数据的字段。
BooleanFieldclass BooleanField(**options)真/假字段。该字段的默认表单小部件是 CheckboxInput。
CharFieldclass DateField(auto_now=False, auto_now_add=False, **options)它是一个日期,在 Python 中由 datetime.date 实例表示。
DateTimeFieldclass DateTimeField(auto_now=False, auto_now_add=False, **options)它是一个日期,在 Python 中由 datetime.date 实例表示。
DateTimeFieldclass DateTimeField(auto_now=False, auto_now_add=False, **options)它用于日期和时间,在 Python 中由 datetime.datetime 实例表示。
DecimalFieldclass DecimalField(max_digits=None, decimal_places=None, **options)它是一个固定精度的十进制数,在 Python 中由 Decimal 实例表示。
DurationFieldclass DurationField(**options)用于存储时间段的字段。
EmailFieldclass EmailField(max_length=254, **options)它是一个 CharField,用于检查该值是否是有效的电子邮件地址。
FileFieldclass FileField(upload_to=None, max_length=100, **options)这是一个文件上传字段。
FloatFieldclass FloatField(**options)它是 Python 中由 float 实例表示的浮点数。
ImageFieldclass ImageField(upload_to=None, height_field=None, width_field=None, max_length=100, **options)它继承了 FileField 的所有属性和方法,但也验证上传的对象是有效的图像。
IntegerFieldclass IntegerField(**options)它是一个整数字段。从 -2147483648 到 2147483647 的值在 Django 支持的所有数据库中都是安全的。
NullBooleanFieldclass NullBooleanField(**options)与 BooleanField 类似,但允许 NULL 作为选项之一。
PositiveIntegerFieldclass PositiveIntegerField(**options)与 IntegerField 类似,但必须为正数或零 (0)。0 到 2147483647 之间的值在 Django 支持的所有数据库中都是安全的。
SmallIntegerFieldclass SmallIntegerField(**options)它类似于 IntegerField,但只允许某个(依赖于数据库)点以下的值。
TextFieldclass TextField(**options)一个大的文本字段。该字段的默认表单小部件是文本区域。
TimeFieldclass TimeField(auto_now=False, auto_now_add=False, **options)时间,在 Python 中由 datetime.time 实例表示。

Django 模型字段示例

# for creating varchar column
first_name = models.CharField(max_length=50)
# for creating date column
release_date = models.DateField()
# for creating integer column
num_stars = models.IntegerField()

字段选项

每个字段都需要一些用于设置列属性的参数。例如,CharField 需要 mac_length 来指定 varchar 数据库。

适用于所有字段类型的通用参数。全部都是可选的。

Field OptionsParticulars
NullDjango 将在数据库中将空值存储为 NULL。
Blank它用于允许字段为空白。
Choices用作该字段的选择的可迭代(例如,列表或元组)的二元组。
Default该字段的默认值。这可以是一个值或一个可调用对象。
help_text与表单小部件一起显示的额外“帮助”文本。即使您的字段未在表单上使用,它对于文档也很有用。
primary_key该字段是模型的主键。
Unique该字段在整个表中必须是唯一的。

Django 模型示例

我们创建了一个模型 Student,其中在models.py文件中包含以下代码。

//模型.py

class Student(models.Model):  
    first_name = models.CharField(max_length=20)  
    last_name  = models.CharField(max_length=30)  
    contact    = models.IntegerField()  
    email      = models.EmailField(max_length=50)  
    age        = models.IntegerField()  

之后,使用以下命令应用迁移。

python3 manage.py makemigrations myapp  

它将创建一个表myapp_student。表结构如下所示。

1.png

标签: django语言, django教程, django技术, django学习, django学习教程, django下载, django开发, django入门教程, django进阶教程, django高级教程, django面试题, django笔试题, django编程思想