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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
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);




相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
7天前
|
Linux 数据库管理 Python
CentOS7编译安装Python3.10(含OpenSSL1.1.1安装),创建虚拟环境,运行Django项目(含sqlite版本报错)
CentOS7编译安装Python3.10(含OpenSSL1.1.1安装),创建虚拟环境,运行Django项目(含sqlite版本报错)
66 4
|
4天前
|
开发框架 数据库 开发者
Web开发新境界:用Python玩转Django和Flask!
【6月更文挑战第12天】Python的Web开发框架Django和Flask各有千秋。Django是全能型框架,适合快速开发大型应用,提供ORM、模板引擎、URL路由和后台管理等全面功能。Flask则轻量级且灵活,适用于小型到中型应用,以其简单易用、高度可扩展和灵活路由著称。两者结合使用,能应对各种Web开发需求。
|
1天前
|
机器学习/深度学习 调度 Python
SOFTS: 时间序列预测的最新模型以及Python使用示例
这是2024年4月《SOFTS: Efficient Multivariate Time Series Forecasting with Series-Core Fusion》中提出的新模型,采用集中策略来学习不同序列之间的交互,从而在多变量预测任务中获得最先进的性能。
11 4
|
1天前
|
小程序 前端开发 JavaScript
计算机Python项目|django傣族节日及民间故事推广小程序
计算机Python项目|django傣族节日及民间故事推广小程序
|
2天前
|
前端开发 JavaScript 数据安全/隐私保护
计算机Python项目|django学生成绩管理系统
计算机Python项目|django学生成绩管理系统
|
2天前
|
弹性计算 关系型数据库 数据库
手把手带你从自建 MySQL 迁移到云数据库,一步就能脱胎换骨
阿里云瑶池数据库来开课啦!自建数据库迁移至云数据库 RDS原来只要一步操作就能搞定!
|
5天前
|
缓存 运维 Serverless
Serverless 应用引擎产品使用合集之基于django应用模板创建的FC,如何配置数据库
阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。
|
8天前
|
数据采集 存储 数据库
优化 Django 模型设计:解决重复爬虫任务和商品数据
在开发数据采集(爬虫)应用时,我们常常面临这样一个问题:不同用户提交了相同的采集任务。为了避免在数据库中存储重复的 URL 和商品数据,我们需要优化模型设计。本文将介绍如何设计 Django 模型,以解决这个问题,并确保数据的一致性和完整性。
|
9天前
|
机器学习/深度学习 自然语言处理 TensorFlow
使用Python实现深度学习模型:Transformer模型
使用Python实现深度学习模型:Transformer模型
20 0
使用Python实现深度学习模型:Transformer模型
|
9天前
|
数据库 Python
Django——数据库
Django——数据库