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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: [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);




相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
9天前
|
SQL 关系型数据库 数据库
Python SQLAlchemy模块:从入门到实战的数据库操作指南
免费提供Python+PyCharm编程环境,结合SQLAlchemy ORM框架详解数据库开发。涵盖连接配置、模型定义、CRUD操作、事务控制及Alembic迁移工具,以电商订单系统为例,深入讲解高并发场景下的性能优化与最佳实践,助你高效构建数据驱动应用。
105 7
|
2月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。
|
3月前
|
存储 运维 关系型数据库
从MySQL到云数据库,数据库迁移真的有必要吗?
本文探讨了企业在业务增长背景下,是否应从 MySQL 迁移至云数据库的决策问题。分析了 MySQL 的优势与瓶颈,对比了云数据库在存储计算分离、自动化运维、多负载支持等方面的优势,并提出判断迁移必要性的五个关键问题及实施路径,帮助企业理性决策并落地迁移方案。
|
5月前
|
人工智能 运维 关系型数据库
数据库运维:mysql 数据库迁移方法-mysqldump
本文介绍了MySQL数据库迁移的方法与技巧,重点探讨了数据量大小对迁移方式的影响。对于10GB以下的小型数据库,推荐使用mysqldump进行逻辑导出和source导入;10GB以上可考虑mydumper与myloader工具;100GB以上则建议物理迁移。文中还提供了统计数据库及表空间大小的SQL语句,并讲解了如何使用mysqldump导出存储过程、函数和数据结构。通过结合实际应用场景选择合适的工具与方法,可实现高效的数据迁移。
874 1
|
2月前
|
数据采集 关系型数据库 MySQL
python爬取数据存入数据库
Python爬虫结合Scrapy与SQLAlchemy,实现高效数据采集并存入MySQL/PostgreSQL/SQLite。通过ORM映射、连接池优化与批量提交,支持百万级数据高速写入,具备良好的可扩展性与稳定性。
|
2月前
|
存储 数据库 开发者
Python SQLite模块:轻量级数据库的实战指南
本文深入讲解Python内置sqlite3模块的实战应用,涵盖数据库连接、CRUD操作、事务管理、性能优化及高级特性,结合完整案例,助你快速掌握SQLite在小型项目中的高效使用,是Python开发者必备的轻量级数据库指南。
195 0
|
5月前
|
关系型数据库 MySQL 数据库
MySQL数据库上云迁移
本文介绍了将数据库迁移到RDS for Mysql的两种主要方法:停服迁移和不停服迁移。停服迁移适合可短暂中断服务的场景,通过mysqldump或DTS完成;不停服迁移适用于需保持业务连续性的场景,推荐使用DTS实现结构、全量及增量数据迁移。文中详细列出了每种方法的具体操作步骤,帮助企业根据需求选择合适的迁移方案。
122 1
MySQL数据库上云迁移
|
6月前
|
人工智能 数据挖掘 API
基于neo4j数据库和dify大模型框架的rag模型搭建——后续补充
基于neo4j数据库和dify大模型框架的rag模型搭建——后续补充
647 21
基于neo4j数据库和dify大模型框架的rag模型搭建——后续补充
|
3月前
|
存储 人工智能 数据库
视图是什么?为什么要用视图呢?数据库视图:定义、特点与应用
本文三桥君深入探讨数据库视图的概念与应用,从定义特点到实际价值全面解析。视图作为虚拟表具备动态更新、简化查询、数据安全等优势,能实现多角度数据展示并保持数据库重构的灵活性。产品专家三桥君还分析了视图与基表关系、创建维护要点及性能影响,强调视图是提升数据库管理效率的重要工具。三桥君通过系统讲解,帮助读者掌握这一常被忽视却功能强大的数据库特性。
635 0

推荐镜像

更多