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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: [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 
相关文章
|
3月前
|
存储 机器学习/深度学习 人工智能
稀疏矩阵存储模型比较与在Python中的实现方法探讨
本文探讨了稀疏矩阵的压缩存储模型及其在Python中的实现方法,涵盖COO、CSR、CSC等常见格式。通过`scipy.sparse`等工具,分析了稀疏矩阵在高效运算中的应用,如矩阵乘法和图结构分析。文章还结合实际场景(推荐系统、自然语言处理等),提供了优化建议及性能评估,并展望了稀疏计算与AI硬件协同的未来趋势。掌握稀疏矩阵技术,可显著提升大规模数据处理效率,为工程实践带来重要价值。
141 58
|
10天前
|
机器学习/深度学习 算法 调度
【切负荷】计及切负荷和直流潮流(DC-OPF)风-火-储经济调度模型研究【IEEE24节点】(Python代码实现)
【切负荷】计及切负荷和直流潮流(DC-OPF)风-火-储经济调度模型研究【IEEE24节点】(Python代码实现)
|
4月前
|
SQL 数据库 开发者
Python中使用Flask-SQLAlchemy对数据库的增删改查简明示例
这样我们就对Flask-SQLAlchemy进行了一次简明扼要的旅程,阐述了如何定义模型,如何创建表,以及如何进行基本的数据库操作。希望你在阅读后能对Flask-SQLAlchemy有更深入的理解,这将为你在Python世界中从事数据库相关工作提供极大的便利。
447 77
|
3月前
|
机器学习/深度学习 人工智能 PyTorch
200行python代码实现从Bigram模型到LLM
本文从零基础出发,逐步实现了一个类似GPT的Transformer模型。首先通过Bigram模型生成诗词,接着加入Positional Encoding实现位置信息编码,再引入Single Head Self-Attention机制计算token间的关系,并扩展到Multi-Head Self-Attention以增强表现力。随后添加FeedForward、Block结构、残差连接(Residual Connection)、投影(Projection)、层归一化(Layer Normalization)及Dropout等组件,最终调整超参数完成一个6层、6头、384维度的“0.0155B”模型
178 11
200行python代码实现从Bigram模型到LLM
|
3月前
|
Linux 数据库 数据安全/隐私保护
Python web Django快速入门手册全栈版,共2590字,短小精悍
本教程涵盖Django从安装到数据库模型创建的全流程。第一章介绍Windows、Linux及macOS下虚拟环境搭建与Django安装验证;第二章讲解项目创建、迁移与运行;第三章演示应用APP创建及项目汉化;第四章说明超级用户创建与后台登录;第五章深入数据库模型设计,包括类与表的对应关系及模型创建步骤。内容精炼实用,适合快速入门Django全栈开发。
92 1
|
4月前
|
机器学习/深度学习 人工智能 算法
Python+YOLO v8 实战:手把手教你打造专属 AI 视觉目标检测模型
本文介绍了如何使用 Python 和 YOLO v8 开发专属的 AI 视觉目标检测模型。首先讲解了 YOLO 的基本概念及其高效精准的特点,接着详细说明了环境搭建步骤,包括安装 Python、PyCharm 和 Ultralytics 库。随后引导读者加载预训练模型进行图片验证,并准备数据集以训练自定义模型。最后,展示了如何验证训练好的模型并提供示例代码。通过本文,你将学会从零开始打造自己的目标检测系统,满足实际场景需求。
1793 0
Python+YOLO v8 实战:手把手教你打造专属 AI 视觉目标检测模型
|
6月前
|
数据库 Python
【YashanDB知识库】python驱动查询gbk字符集崖山数据库CLOB字段,数据被驱动截断
【YashanDB知识库】python驱动查询gbk字符集崖山数据库CLOB字段,数据被驱动截断
|
3月前
|
人工智能 运维 关系型数据库
数据库运维:mysql 数据库迁移方法-mysqldump
本文介绍了MySQL数据库迁移的方法与技巧,重点探讨了数据量大小对迁移方式的影响。对于10GB以下的小型数据库,推荐使用mysqldump进行逻辑导出和source导入;10GB以上可考虑mydumper与myloader工具;100GB以上则建议物理迁移。文中还提供了统计数据库及表空间大小的SQL语句,并讲解了如何使用mysqldump导出存储过程、函数和数据结构。通过结合实际应用场景选择合适的工具与方法,可实现高效的数据迁移。
559 1
|
4月前
|
负载均衡 算法 关系型数据库
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
本文聚焦 MySQL 集群架构中的负载均衡算法,阐述其重要性。详细介绍轮询、加权轮询、最少连接、加权最少连接、随机、源地址哈希等常用算法,分析各自优缺点及适用场景。并提供 Java 语言代码实现示例,助力直观理解。文章结构清晰,语言通俗易懂,对理解和应用负载均衡算法具有实用价值和参考价值。
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
|
3月前
|
SQL 关系型数据库 MySQL
Go语言数据库编程:使用 `database/sql` 与 MySQL/PostgreSQL
Go语言通过`database/sql`标准库提供统一数据库操作接口,支持MySQL、PostgreSQL等多种数据库。本文介绍了驱动安装、连接数据库、基本增删改查操作、预处理语句、事务处理及错误管理等内容,涵盖实际开发中常用的技巧与注意事项,适合快速掌握Go语言数据库编程基础。
202 62

热门文章

最新文章

推荐镜像

更多