[Python]Django模型的定义 & 修改数据库引擎 & 迁移

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用版 2核4GB 50GB
简介: [Python]Django模型的定义 & 修改数据库引擎 & 迁移

c0872fd493f543a6860e724408c329a9.jpg

前言

系列文章目录

[Python]目录

视频及资料和课件

链接:https://pan.baidu.com/s/1LCv_qyWslwB-MYw56fjbDg?pwd=1234

提取码:1234

1. ORM框架

在ORM框架中,类对应数据表,对象对应数据表中的行,对象的属性对应数据表中对应行的字段。

2. 定义模型类

2.1 模型类的定义

  1. 定义模型类时,需要继承models.Model.
  2. 定义模型类,模型类会自动添加或生成一个主键(即id)
  • django会为表创建自动增长的主键列,每个模型只能有一个主键列,如果使用选项设置某属性为主键列后django不会再创建自动增长的主键列。
  1. 定义属性,使用属性名 = 属性类型(选项)进行定义
  • 属性名:不要使用python或mysql关键字;不要使用连续的下划线__
  • 属性类型:与mysql的字段类型类似,使用models.属性类型()
  • 选项:CharField必须设置max_length(字符的最大个数);选项设置null=True表示值允许为空;unique=True表示该属性的取值唯一;default=0表示设置默认值为0;verbose_name=''设置模型在admin后台显示的名字。

定义一个模型类:

书籍表:

id,name,pub_date(发布日期),read_count(阅读数),comment_count(评论数),is_delete(是否删除)

from django.db import models
# Create your models here.
class BookInfo(models.Model):
    # 定义属性:属性名 = 属性类型(选项)
    # 由于id会自动生成所以属性id不用进行定义
    # name
    # 书籍名最大的个数不能超过10,且书籍名唯一,在admin后台显示的属性名字为书籍名
    name = models.CharField(max_length=10, unique=True, verbose_name='书籍名')
    # 发布日期
    # 该属性允许为空
    pub_date = models.DateField(null=True)
    # 阅读数
    # 默认值为0
    read_count = models.IntegerField(default=0)
    # 评论数
    # 默认值为0
    comment_count = models.IntegerField(default=0)
    # 是否被逻辑删除
    # 默认值为False
    is_delete = models.BooleanField(default=False)

2.2 定义模型类属性可以选择的类型

2.3 定义模型类属性可以设置的配置选项

null是数据库范畴的概念,blank是表单验证范畴的

2.4 模型对应数据库表名的定义

定义模型在数据库中对应的表的表名,在内部类class Meta中进行定义。

模型类如果未指明表名,Django默认以小写app应用名_小写模型类名为数据库表名。可通过db_table指明数据库表名。

from django.db import models
# Create your models here.
class BookInfo(models.Model):
    # 定义属性:属性名 = 属性类型(选项)
    # 由于id会自动生成所以属性id不用进行定义
    # name
    # 书籍名最大的个数不能超过10,且书籍名唯一,在admin后台显示的属性名字为书籍名
    name = models.CharField(max_length=10, unique=True, verbose_name='书籍名')
    # 发布日期
    # 该属性允许为空
    pub_date = models.DateField(null=True)
    # 阅读数
    # 默认值为0
    read_count = models.IntegerField(default=0)
    # 评论数
    # 默认值为0
    comment_count = models.IntegerField(default=0)
    # 是否被逻辑删除
    # 默认值为False
    is_delete = models.BooleanField(default=False)
    class Meta:
        # 修改模型对应数据库中表的表名
        db_table = 'bookinfo'
        # 修改后台admin的显示信息的配置
        verbose_name = '书籍信息'

2.5 重写__str__()修改数据对象的显示

from django.db import models
# Create your models here.
class BookInfo(models.Model):
    # 定义属性:属性名 = 属性类型(选项)
    # 由于id会自动生成所以属性id不用进行定义
    # name
    # 书籍名最大的个数不能超过10,且书籍名唯一,在admin后台显示的属性名字为书籍名
    name = models.CharField(max_length=10, unique=True, verbose_name='书籍名')
    # 发布日期
    # 该属性允许为空
    pub_date = models.DateField(null=True)
    # 阅读数
    # 默认值为0
    read_count = models.IntegerField(default=0)
    # 评论数
    # 默认值为0
    comment_count = models.IntegerField(default=0)
    # 是否被逻辑删除
    # 默认值为False
    is_delete = models.BooleanField(default=False)
    class Meta:
        # 修改模型对应数据库中表的表名
        db_table = 'bookinfo'
        # 修改后台admin的显示信息
        verbose_name = '书籍信息'
    def __str__(self):
        return self.name

2.6 模型外键的定义

在设置外键时,需要通过on_delete选项指明主表删除数据时,对于外键引用表数据如何处理,在django.db.models中包含了可选常量:

  • CASCADE级联,删除主表数据时连通一起删除外键表中数据
  • PROTECT保护,通过抛出ProtectedError异常,来阻止删除主表中被外键引用的数据
  • SET_NULL设置为NULL,仅在该字段null=True允许为null时可用
  • SET_DEFAULT设置为默认值,仅在该字段设置了默认值时可用
  • SET()设置为特定值或者调用特定方法
  • DO_NOTHING不做任何操作,如果数据库前置指明级联性,此选项会抛出IntegrityError异常

实现:

定义一个模型类,记录每本书籍中人物的信息。

# 引用外键,引用的模型为BookInfo,当BookInfo中的信息被删除时,人物信息表中对应的信息对象执行级联删除
book = models.ForeignKey(BookInfo, on_delete=models.CASCADE, verbose_name='图书')  # 外键
# 准备人物列表信息的模型类
class PeopleInfo(models.Model):
  # 顺序字典
  # 0对应male
  # 1对应female
    GENDER_CHOICES = (
        (0, 'male'),
        (1, 'female')
    )
    # 人物的名字
    # 名字最长为20个字符,在admin后台显示的为名称
    name = models.CharField(max_length=20, verbose_name='名称')
    # 人物的性别,类型SmallIntegerField所占内存小,取值从上面定义的字典列表中选取,要么0要么1,默认取值为0,admin后台显示的为性别
    gender = models.SmallIntegerField(choices=GENDER_CHOICES, default=0, verbose_name='性别')
    # 人物的描述信息,最长为200个字符,允许为空
    description = models.CharField(max_length=200, null=True, verbose_name='描述信息')
    # 引用外键,引用的模型为BookInfo,当BookInfo中的信息被删除时,人物信息表中对应的信息对象执行级联删除
    book = models.ForeignKey(BookInfo, on_delete=models.CASCADE, verbose_name='图书')  # 外键
    # 是否被逻辑删除,默认值为False
    is_delete = models.BooleanField(default=False, verbose_name='逻辑删除')
    class Meta:
      # 数据库中显示的表名
        db_table = 'peopleinfo'
        # 表在admin后台的显示
        verbose_name = '人物信息'
  # 设置数据对象的显示为对象的名字
    def __str__(self):
        return self.name

3. 修改数据库引擎

Django默认使用的数据库引擎为sqlite3,sqlite是一个嵌入式的关系型数据库。sqlite是一个小型的关系型数据库,主要用于移动端。

中型数据库:MySQL、SQLserver

大型数据库:oracle、DB2

修改数据库引擎,修改项目的配置文件settings.py中的配置项DATABASES即可。

DATABASES = {
    'default': {
        # 设置数据库引擎
        # 修改数据库引擎为mysql
        'ENGINE': 'django.db.backends.mysql',
        # 'NAME': BASE_DIR / 'db.sqlite3',
    }
}

修改数据库引擎为mysql,即需要使用python来操作mysql数据库,所以需要在虚拟环境中下载pymysql包。

pip install PyMySQL

下载PyMySQL后,在项目文件夹中的__init__.py文件导入PyMySQL作为项目的MySQL数据库。

import pymysql
# PyMySQL作为项目的MySQL数据库
pymysql.install_as_MySQLdb()

接下来配置连接mysql数据库的主机、端口号、用户名、密码、使用的数据库等。

DATABASES = {
    'default': {
        # 设置数据库引擎
        # 修改数据库引擎为mysql
        'ENGINE': 'django.db.backends.mysql',
        # 主机
        'HOST': '127.0.0.1',
        # 端口号
        'PORT': '3306',
        # 用户名
        'USER': 'root',
        # 密码
        'PASSWORD': '285013',
        # 使用的数据库(前提:在mysql中对应的数据库要存在)
        'NAME': 'book'
        # 'NAME': BASE_DIR / 'db.sqlite3',
    }
}

4. 迁移

4.1 生成迁移文件

python manage.py makemigrations

如果报错:

No changes detected

原因:子应用没有进行注册

4.2 迁移同步到数据库中

python manage.py migrate

5. 数据库导入数据

bookinfo:

insert into bookinfo(name, pub_date, read_count,comment_count, is_delete) values
('射雕英雄传', '1980-5-1', 12, 34, 0),
('天龙八部', '1986-7-24', 36, 40, 0),
('笑傲江湖', '1995-12-24', 20, 80, 0),
('雪山飞狐', '1987-11-11', 58, 24, 0);

peopleinfo:

insert into peopleinfo(name, gender, book_id, description, is_delete)  values
    ('郭靖', 1, 1, '降龙十八掌', 0),
    ('黄蓉', 0, 1, '打狗棍法', 0),
    ('黄药师', 1, 1, '弹指神通', 0),
    ('欧阳锋', 1, 1, '蛤蟆功', 0),
    ('梅超风', 0, 1, '九阴白骨爪', 0),
    ('乔峰', 1, 2, '降龙十八掌', 0),
    ('段誉', 1, 2, '六脉神剑', 0),
    ('虚竹', 1, 2, '天山六阳掌', 0),
    ('王语嫣', 0, 2, '神仙姐姐', 0),
    ('令狐冲', 1, 3, '独孤九剑', 0),
    ('任盈盈', 0, 3, '弹琴', 0),
    ('岳不群', 1, 3, '华山剑法', 0),
    ('东方不败', 0, 3, '葵花宝典', 0),
    ('胡斐', 1, 4, '胡家刀法', 0),
    ('苗若兰', 0, 4, '黄衣', 0),
    ('程灵素', 0, 4, '医术', 0),
    ('袁紫衣', 0, 4, '六合拳', 0);




相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2天前
|
SQL NoSQL 数据库
在Python中使用sqlalchemy来操作数据库的几个小总结
在探索使用 FastAPI, SQLAlchemy, Pydantic,Redis, JWT 构建的项目的时候,其中数据库访问采用SQLAlchemy,并采用异步方式。数据库操作和控制器操作,采用基类继承的方式减少重复代码,提高代码复用性。在这个过程中设计接口和测试的时候,对一些问题进行跟踪解决,并记录供参考。
|
4天前
|
对象存储 Python
Python代码解读-理解-定义一个User类的基本写法
以上描述清晰地阐述了如何在Python中定义 `User`类的基本方法以及如何创建和使用该类的实例。这是面向对象编程中的核心概念,是紧密结合抽象和实现,封装数据并提供操作数据的接口。由于用简单通用的语言易于理解,这样的解释对于初学者而言应该是友好且有帮助的。
13 4
|
3天前
|
SQL JSON C语言
Python中字符串的三种定义方法
Python中字符串的三种定义方法
|
4天前
|
前端开发 JavaScript Java
SpringBoot+Vue+token实现(表单+图片)上传、图片地址保存到数据库。上传图片保存位置自己定义、图片可以在前端回显(一))
这篇文章详细介绍了在SpringBoot+Vue项目中实现表单和图片上传的完整流程,包括前端上传、后端接口处理、数据库保存图片路径,以及前端图片回显的方法,同时探讨了图片资源映射、token验证、过滤器配置等相关问题。
|
5天前
|
JSON NoSQL Ubuntu
在Ubuntu 14.04上如何备份、恢复和迁移MongoDB数据库
在Ubuntu 14.04上如何备份、恢复和迁移MongoDB数据库
15 1
|
5天前
|
关系型数据库 数据库 数据安全/隐私保护
"告别繁琐!Python大神揭秘:如何一键定制阿里云RDS备份策略,让数据安全与效率并肩飞,轻松玩转云端数据库!"
【8月更文挑战第14天】在云计算时代,数据库安全至关重要。阿里云RDS提供自动备份,但标准策略难以适应所有场景。传统手动备份灵活性差、管理成本高且恢复效率低。本文对比手动备份,介绍使用Python自定义阿里云RDS备份策略的方法,实现动态调整备份频率、集中管理和智能决策,提升备份效率与数据安全性。示例代码演示如何创建自动备份任务。通过自动化与智能化备份管理,支持企业数字化转型。
16 2
|
10天前
|
SQL 关系型数据库 MySQL
Python系列:教你使用PyMySQL操作MySQL数据库
Python系列:教你使用PyMySQL操作MySQL数据库
21 8
|
8天前
|
存储 数据库连接 数据库
【Python】python员工信息管理系统(数据库版本)(GUI界面+数据库文件+源码)【独一无二】
【Python】python员工信息管理系统(数据库版本)(GUI界面+数据库文件+源码)【独一无二】
|
9月前
|
SQL 关系型数据库 MySQL
07 Django模型 - ORM简介及MySQL数据库的使用
07 Django模型 - ORM简介及MySQL数据库的使用
53 0
|
数据库 Python 关系型数据库
Django模型简介
模型是一个定义数据源的数据,它包含要存储数据的一些属性和行为。通常,每一个模型对应数据库中的一个数据表。 每一个模型是django.db.models.Model的子类 每一个模型属性代表数据表的一个字段。