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

相关推荐
汤姆yu1 小时前
基于springboot的智能化人员物资调度系统
数据库·spring boot·后端
一 乐1 小时前
宠物店管理|基于Java+vue的宠物猫店管理管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
我的offer在哪里1 小时前
mysql的底层文件分析
数据库·mysql·adb
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ1 小时前
sql计算去除值后面的零
数据库·sql
leafff1231 小时前
智能体架构深度解析::一文了解LangChain、LangGraph与MCP框架集成原理分析
数据库·人工智能
ChrylZzz1 小时前
【SQL】大小表查询、更新表语句
数据库·sql
深藏bIue1 小时前
Oracle修改完sga、pga启动失败处理方案
数据库·oracle
AI浩1 小时前
【Redis】Windows下Redis环境搭建与使用详细教程
数据库·windows·redis
卿雪1 小时前
认识Redis:Redis 是什么?好处?业务场景?和MySQL的区别?
服务器·开发语言·数据库·redis·mysql·缓存·golang