django迁移表结构和数据

一、创建django项目和应用模块

参考本人另一篇文章前四步Python框架Django入门教程

二、编写model层

在demo模块下的models.py中添加以下代码:

python 复制代码
from django.db import models

class User(models.Model):
    class Meta:
        # 设置所需要映射的数据表,默认映射的表名是:应用名_全小写类名
        db_table = "user"
        # 约束、索引
        constraints = [
            # UniqueConstraint唯一约束;fields字段名,可以是多个字段,实现多个字段组合后的唯一性
            models.UniqueConstraint(fields=["account"], name="account_unique")
        ]

    ISDEL_CHOICES = (
        (0, "未删除"),
        (1, "已删除")
    )

    # Django自带id字段,默认类型是BigAutoField,自动递增的bigint类型字段,可手动定义
    # id = models.CharField(max_length=30, primary_key=True)
    # varchar类型字段,max_length最大长度,default默认值(仅ORM层生效,表结构没有default),verbose_name字段注释
    name = models.CharField(max_length=20, default="", verbose_name="姓名")
    account = models.CharField(max_length=20, verbose_name="账号")
    password = models.CharField(max_length=16, verbose_name="密码")
    gender = models.CharField(max_length=1, verbose_name="性别")
    # int类型字段
    age = models.IntegerField()
    # Decimal类型的字段,max_digits总长度,decimal_places小数点位数
    money = models.DecimalField(max_digits=10, decimal_places=2)
    # datetime类型字段,默认长度为6存储微秒级时间;auto_now_add=True添加数据时自动填充时间
    create_time = models.DateTimeField(auto_now_add=True)
    # datetime类型字段,默认长度为6存储微秒级时间;auto_now=True添加或更新数据时自动填充时间
    update_time = models.DateTimeField(auto_now=True)
    # null=True允许该字段为null值
    note = models.CharField(max_length=200, null=True)
    # choices限制字段的取值范围,只能是0和1,只是形式上限制,实际执行user.del=2时并不会报错,可以正常插入到数据库
    isdel = models.IntegerField(default=0, choices=ISDEL_CHOICES)

三、迁移表结构

PyCharm打开终端,执行命令:

根据demo模块中的所有model生成迁移文件,文件位置在demo/migrations/

python manage.py makemigrations demo

根据demo模块中的所有迁移文件,创建或修改表结构

python manage.py migrate demo

迁移成功后,django会自动在数据库中创建一张django_migrations表,用于跟踪迁移记录;当model层中出现变更时,可以再次执行makemigrations和migrate命令生成迁移文件并将变更应用到数据库中

四、migrate创建的表结构与model层的一些表现差异

migrate迁移命令所创建的user表结构:

CREATE TABLE `user` (

`id` bigint(20) NOT NULL AUTO_INCREMENT,

`name` varchar(20) NOT NULL,

`account` varchar(20) NOT NULL,

`password` varchar(16) NOT NULL,

`gender` varchar(1) NOT NULL,

`age` int(11) NOT NULL,

`money` decimal(10,2) NOT NULL,

`create_time` datetime(6) NOT NULL,

`update_time` datetime(6) NOT NULL,

`note` varchar(200) DEFAULT NULL,

`isdel` int(11) NOT NULL,

PRIMARY KEY (`id`),

UNIQUE KEY `account_unique` (`account`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

原因:dajngo自身特性所致,model层字段的部分属性并不会直接作用在表结构上

  1. default属性,例如isdel字段的default=0,虽然表结构中并没有 DEFAULT 0,但是在使用dajngo ORM时,会自动为user.isdel赋默认值

  2. datetime类型字段,默认长度为6,存储微秒级精度的时间

五、迁移表数据

在第一次创建表后可能需要一些基础数据,例如user表中需要带有一条admin的账号

  1. 在demo模块下创建文件fixtures/user.yaml,时间字段需要手动配置,isdel则会默认填充0(不知道时间字段为啥不触发自动填充)
  • model: demo.User

fields:

id: 1

name: admin

account: admin@qq.com

password: 123456

gender: 男

age: 16

money: 0.00

create_time: 2023-01-15 00:35:00+08:00

update_time: 2023-01-15 00:35:00+08:00

  • model: demo.User

fields:

id: 2

name: 派蒙

account: paimeng@qq.com

...

  1. 执行命令,向user表中插入数据

python manage.py loaddata user.yaml

相关推荐
大模型玩家七七4 分钟前
安全对齐不是消灭风险,而是重新分配风险
android·java·数据库·人工智能·深度学习·安全
wxin_VXbishe4 分钟前
springboot旅游信息管理系统-计算机毕业设计源码21675
java·c++·spring boot·python·spring·django·php
李少兄4 分钟前
MySQL 中为时间字段设置默认当前时间
android·数据库·mysql
码海踏浪13 分钟前
从简单到专业在OceanBase中查看SQL是否走索引
数据库·sql·oceanbase
qinyia14 分钟前
**使用AI助手在智慧运维中快速定位并修复服务异常:以Nginx配置错误导致502错误为例**
linux·运维·服务器·数据库·mysql·nginx·自动化
熊文豪20 分钟前
关系数据库替换用金仓——Oracle兼容性深度解析
数据库·oracle·金仓数据库·电科金仓·kes
eWidget26 分钟前
面向Oracle生态的国产高兼容数据库解决方案
数据库·oracle·kingbase·数据库平替用金仓·金仓数据库
A懿轩A29 分钟前
【MySQL 数据库】MySQL 数据库核心概念详解:库、表、字段、主键与关系型模型一文读懂
数据库·mysql·oracle
盒马coding33 分钟前
postgreSQL中调整Checkpoint的重要性
数据库·mysql·postgresql
怣5042 分钟前
MySQL多表连接完全指南:内连接与外连接(零基础入门版)
数据库·mysql