Django学习-Django数据库模型定义

文章目录

      • 定义模型
        • [1. 实现方法](#1. 实现方法)
        • [2. 模型字段类型](#2. 模型字段类型)
        • [3. 模型字段参数](#3. 模型字段参数)
        • [4. Meta选项属性](#4. Meta选项属性)
        • [5. 模型定义示例](#5. 模型定义示例)

Django对各种数据库提供了很好的支持,包括PostgreSQL、MySQL、SQLite和Oracle,而且为这些数据库提供了统一的API方法,这些API统称为ORM框架。

定义模型

ORM框架是一种程序技术,用于实现面向对象编程语言中不同类型系统的数据之间的转换。它创建了一个可在编程语言中使用的虚拟对象数据库,在django中,虚拟对象数据库也被称为模型,通过模型实现对目标数据库的读写操作。

1. 实现方法
  • 配置目标数据库,在setting.py中设置数据库配置。
  • 构建虚拟对象数据库,在App的models.py文件中以类的形式定义模型。
  • 通过模型迁移命令在目标数据库中创建相应的数据表。
  • 在其他模块(如视图函数)里使用模型来实现目标数据库的读写操作。
2. 模型字段类型

模型字段类型可在源码目录django\db\models\fields__init__.pyfiles.py文件中找到。
常见常用模型字段示例如下:

字段名称 字段介绍
AutoField 自增长类型,数据表的字段类型为整数,长度为11位。
CharField 字符类型
BooleanField 布尔类型
DateField 日期(Date)类型
FloatField 浮点数类型,数据表的字段类型变成Double类型。
IntegerField 整数类型,数据表的字段类型为11位的整数。
TextField 长文本类型
FileField 字符类型,存储文件路径的字符串
ImageField 字符类型,存储图片路径的字符串
3. 模型字段参数

每个模型字段都允许设置参数,这些参数来自父类Field,我们可在源码里查看Field的定义过程(django\db\models\fields\__init__.py)并且对模型字段的参数进行分析。
常见常用模型字段参数:

字段参数名称 介绍
verbose_name 默认为None,在Admin站点管理设置字段的显示名称。
primary_key 默认为False,若为True,则将字段设置成主键。
max_length 默认为None,设置字段的最大长度。
unique 默认为False,若为True,则设置字段的唯一属性。
blank 默认为False,若为True,则字段允许为空值,数据库将存储空字符串。
null 默认为False,若为True,则字段允许为空值,数据库表现为NULL。
db_index 默认为False,若为True,则以此字段来创建数据库索引。
db_column 默认为None,设置数据表的列名称,若不设置,则将字段名作为数据表的列名。
default 默认为NOT_PROVIDED对象,设置字段的默认值。
validators 默认为空列表,设置字段内容的验证函数。

注意:

上述参数适用于所有模型字段,但不同类型的字段回应一些特殊参数,每个字段的特殊参数可以在字段的初始化方法__init__里找到,比如字段DateFieldTimeField的特殊参数auto_now_addauto_now,字段FileFieldImageField的特殊参数upload_to

4. Meta选项属性

Meta 类是用于定义模型元数据的内部类。它允许你指定一些与模型相关的选项和配置,例如排序方式、数据库表名、唯一性约束等。
常见常用模型字段参数:

Meta选项属性 介绍
abstract 若设为True,则该模型为抽象模型,不会在数据库里创建数据表。
app_label 属性值为字符串,将模型设置为指定的项目应用,比如将index的models.py定义的模型A指定到其他App里。
db_table 属性值为字符串,设置模型所对应的数据表名称。
get_latest_by 属性值为字符串或列表,设置模型数据的排序方式。
managed 默认值为True,支持Django命令执行数据迁移;若为False,则不支持数据迁移功能。
proxy 若设为True,则为模型创建代理模型,即克隆一个与模型A相同的模型B。
verbose_name 属性值为字符串,设置模型直观可读的名称并以复数形式表示。
5. 模型定义示例
python 复制代码
class PersonInfo(models.Model):
    # 自动增长的主键,用于唯一标识每个人员
    id = models.AutoField(primary_key=True)
    # 人员姓名,字符串类型,最大长度为20
    name = models.CharField(max_length=20)
    # 人员年龄,整数类型
    age = models.IntegerField()
    # 入职日期,日期类型
    hireDate = models.DateField()

    # 定义对象的字符串表示形式
    # 返回人员的姓名
    def __str__(self):
        return self.name

    # 元类,用于配置模型的元数据
    # 设置模型的可读名称
    class Meta:
        verbose_name = '人员信息'

综上所述,模型字段、函数__str__Meta选项是模型定义的基本要素,模型字段的类型、函数__str__Meta选项的属性设置需由开发需求而定。在定义模型时,还可以在模型里定义相关函数,如get_absolute_url(),当视图类没有设置属性success_url时,视图类的重定向路由地址将由模型定义的get_absolute_url()提供。

除此之外,Django支持开发者自定义模型字段。

相关推荐
m0_748232397 分钟前
WebRTC学习二:WebRTC音视频数据采集
学习·音视频·webrtc
指尖上跳动的旋律39 分钟前
shell脚本定义特殊字符导致执行mysql文件错误的问题
数据库·mysql
一勺菠萝丶1 小时前
MongoDB 常用操作指南(Docker 环境下)
数据库·mongodb·docker
虾球xz1 小时前
游戏引擎学习第55天
学习·游戏引擎
m0_748244832 小时前
StarRocks 排查单副本表
大数据·数据库·python
oneouto2 小时前
selenium学习笔记(二)
笔记·学习·selenium
C++忠实粉丝2 小时前
Redis 介绍和安装
数据库·redis·缓存
sealaugh322 小时前
aws(学习笔记第十九课) 使用ECS和Fargate进行容器开发
笔记·学习·aws
wmd131643067122 小时前
将微信配置信息存到数据库并进行调用
数据库·微信
炭烤玛卡巴卡2 小时前
学习postman工具使用
学习·测试工具·postman