首页 > 编程学习 > [Python]Django模型的定义 修改数据库引擎 迁移

在这里插入图片描述


前言

系列文章目录
[Python]目录
视频及资料和课件
链接:https://pan.baidu.com/s/1LCv_qyWslwB-MYw56fjbDg?pwd=1234
提取码:1234


文章目录

  • 前言
  • 1. ORM框架
  • 2. 定义模型类
    • 2.1 模型类的定义
    • 2.2 定义模型类属性可以选择的类型
    • 2.3 定义模型类属性可以设置的配置选项
    • 2.4 模型对应数据库表名的定义
    • 2.5 重写`__str__()`修改数据对象的显示
    • 2.6 模型外键的定义
  • 3. 修改数据库引擎
  • 4. 迁移
    • 4.1 生成迁移文件
    • 4.2 迁移同步到数据库中
  • 5. 数据库导入数据


1. ORM框架

在ORM框架中,类对应数据表,对象对应数据表中的行,对象的属性对应数据表中对应行的字段。
在这里插入图片描述

2. 定义模型类

2.1 模型类的定义

  1. 定义模型类时,需要继承models.Model.
  2. 定义模型类,模型类会自动添加或生成一个主键(即id)
    • django会为表创建自动增长的主键列,每个模型只能有一个主键列,如果使用选项设置某属性为主键列后django不会再创建自动增长的主键列。
  3. 定义属性,使用属性名 = 属性类型(选项)进行定义
    • 属性名:不要使用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);

在这里插入图片描述

Copyright © 2010-2022 mfbz.cn 版权所有 |关于我们| 联系方式|豫ICP备15888888号