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 小时前
数据治理平台架构演进观察:AI原生设计如何重构企业数据管理范式
数据库·重构·架构·数据治理·ai-native·ai原生
一江寒逸4 小时前
零基础从入门到精通MySQL(中篇):进阶篇——吃透多表查询、事务核心与高级特性,搞定复杂业务SQL
数据库·sql·mysql
D4c-lovetrain4 小时前
linux个人心得22 (mysql)
数据库·mysql
阿里小阿希4 小时前
CentOS7 PostgreSQL 9.2 升级到 15 完整教程
数据库·postgresql
荒川之神4 小时前
Oracle 数据仓库雪花模型设计(完整实战方案)
数据库·数据仓库·oracle
做个文艺程序员4 小时前
MySQL安全加固十大硬核操作
数据库·mysql·安全
不吃香菜学java5 小时前
Redis简单应用
数据库·spring boot·tomcat·maven
一个天蝎座 白勺 程序猿5 小时前
Apache IoTDB(15):IoTDB查询写回(INTO子句)深度解析——从语法到实战的ETL全链路指南
数据库·apache·etl·iotdb
不知名的老吴5 小时前
Redis的延迟瓶颈:TCP栈开销无法避免
数据库·redis·缓存
YOU OU5 小时前
三大范式和E-R图
数据库