django mysql迁移_小谈django数据库迁移

本篇文章将从数据库迁移的原理出发,详细谈一谈在进行数据库迁移过程中的问题。

django框架就是一款强大的ORM框架,可以不需要写sql语句就能进行应用开发。 ————官方说明文档

一、

首先,简短说一下数据库迁移。说白了,其实就是将数据库中的数据导出为sql语句来进行sql操作。而对于django而言,强大之处就在于在通过迁移命令执行数据库迁移后,生成迁移sql语句脚本进行相应的数据库操作。

在数据库迁移之前,我们首先要生成迁移文件,命令耳熟能详

python manage.py makemigrations

或者单独对某一模块进行迁移操作

python manage.py makemigrations [模块名]

这样就生成了迁移文件,在相对应的项目应用中可以看到migrations文件夹下,生成一个新的以数字打头的迁移文件。

而下一步就是执行迁移操作了

python manage.py migrate

或者单独迁移某一模块

python manage.py migrate [模块名]

迁移过之后,我们会发现在数据库中多了迁移模型的数据表,查看相应表也可以看到我们所建立的字段和类型。

但也多了几张表,其中一张便是django_migrations,这张表即是记录我们在每次执行迁移操作时记录的迁移文件的数据表。具体记录的是模块和与其对应的迁移文件名。

二、

在我们协同开发过程中,遇到模型复用和更新迭代是最常见的事情,有时候我们会多次数据库迁移来对旧表进行修改。但随着迭代版本的增加太多的迁移文件有时却让自己很烦,在版本控制时也会产生一些冲突和意想不到的bug。那么有时候就需要重新迁移文件,所以在

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值