django orm 之makemigrations和migrate命令
makemigrations:将模型的更改生成迁移脚本文件。模型所在的app,必须放在settings.py中的INSTALLED_APPS列表中。这个命令有以下几个常用选项:
1、app_label:后面可以跟一个或者多个app,那么就只会针对这几个app中模型的变化生成迁移脚本。如果没有任何的app_label,默认会检查INSTALLED_APPS中所有的app下的模型,针对每一个app中models的改变都生成相应的迁移脚本,注意生成的这些个迁移脚本文件都存放在各个app下的migrations下。
2、--name:给这个迁移脚本指定一个名字,如果不指定名字,那么生成的脚本文件的名称将会不那么见名知意。
3、--empty:生成一个空的迁移脚本。如果你想写自己的迁移脚本,可以使用这个命令来实现一个空的文件,然后自己再在文件中写迁移脚本。
migrate:将新生成的迁移脚本,映射到数据库中,创建新的表或者修改表的结构。执行python manage.py migrate命令会执行两个步骤:
1、执行对应app(默认为INSTALLED_APPS下所有的app,当然也可以指定app名称)下的migrations文件夹下的迁移脚本文件并映射到数据表,除了第一个迁移脚本文件没有依赖,其余的迁移脚本文件都会依赖前一个,在执行迁移脚本文件的时候,django首先会检查'django_migrations'表中的记录,执行指定的迁移脚本(默认为最新的,可以指定app和迁移脚本文件版本名称),会依次执行它依赖的迁移脚本文件,直到这个依赖已经执行过了(会在'django_migrations'有记录)
2、将已经执行的迁移脚本文件记录在django默认生成的'django_migrations'表中
app_label:将某个app下的迁移脚本映射到数据库中。如果没有指定,那么会将所有在INSTALLED_APPS中的app下的模型都映射到数据库中。
app_label migrationname:将某个app下指定名字的migration文件映射到数据库中。
执行migrate命令可能会报错,报错的主要原因是数据库的'django_migrations'表中的迁移版本与对应数据表中的数据表结构生成所需的迁移脚本相冲突。下面两个命令是解决报错的可用方法:
1、--fake:可以将指定的迁移脚本名字添加到数据库中。但是并不会把迁移脚本转换为SQL语句,修改数据库中的表。使用与数据表结构所需迁移脚本比已执行的迁移脚本超前。
2、--fake-initial:将第一次生成的迁移文件版本号记录在数据库中。但并不会真正的执行迁移脚本。使用于迁移脚本文件缺少并且很乱,可以把表的结构与models里的结构弄一致,删除所有迁移脚本,清空所有这个app相关的'django_migrations'数据。执行makmigrations,然后执行--fake-initial,继续正常的些其他表内容
showmigrations:查看某个app下的迁移文件。如果后面没有app,那么将查看INSTALLED_APPS中所有的迁移文件。
sqlmigrate:查看某个迁移文件在映射到数据库中的时候,转换的SQL语句
转载于:https://www.cnblogs.com/limaomao/p/9446091.html
django orm 之makemigrations和migrate命令相关推荐
- Django源码分析7:migrate命令的浅析
django源码分析 本文环境python3.5.2,django1.10.x系列 django源码分析-migrate命令分析 Django项目中提供了,通过migrations操作数据库的结构的命 ...
- Django migrate 命令
Django migrate 命令 初始化app models 表:python manage.py makemigrations (所有模型) 初始化app 某个模块:python manage.p ...
- django orm级联_Django数据表关联关系映射(一对一、一对多、多对多)
我们知道涉及到数据表之间的对应关系就会想到一对一.一对多.多对多,在学习 MySQL 数据库时表关系设计是需要重点掌握的知识.Django 中定义了三种关系类型的字段用来描述数据库表的关联关系:一对多 ...
- django ORM 操作
ORM操作 select * from tb where id > 1 # 对应关系 models.tb.objects.filter(id__gt=1) models.tb.objects.f ...
- Django ORM
Python微信订餐小程序课程视频 https://edu.csdn.net/course/detail/36074 Python实战量化交易理财系统 https://edu.csdn.net/cou ...
- Django ORM 数据库操作
比较有用 转自 http://blog.csdn.net/fgf00/article/details/53678205 一.DjangoORM 创建基本类型及生成数据库表结构 1.简介 2.创建数据库 ...
- makemigrations 和 migrate区分
内容大致是makemigrations 和 migrate 工作原理分别是什么 makemigrations:根据检测到的模型创建新的迁移.迁移的作用,更多的是将数据库的操作,以文件的形式记录下来,方 ...
- makemigrations 和 migrate工作原理分别是什么
有一道关于python-django开发工程师的面试题: 内容大致是makemigrations 和 migrate 工作原理分别是什么, 如果不想使用 Django 的 makemigrations ...
- Django ORM操作
Django ORM操作 一般操作 看专业的官网文档,做专业的程序员! 必知必会13条 <1> all(): 查询所有结果<2> get(**kwargs): 返回与所给筛选条 ...
最新文章
- SmartGit安装及使用
- finally语句块一定会执行吗?
- 打造工业级推荐系统(三):推荐系统的工程实现与架构优化
- linux ls -l 详解
- beaninfo详解源码解析 java_【Spring源码分析】Bean加载流程概览
- 【亲测有效】win10下输入法突然变成繁体了怎么设置回来?
- 远离神经网络这个黑盒,人工智能不止这一条路可走
- c #include如何找到文件_UNIX系统上程序员需要掌握的C编程环境的基础知识
- paip.invalid conversion from FormWdg* to SOCKET {aka unsigned int}
- Java实验报告(七)|IO编程
- numpy 的三角函数运算
- thinkphp6.0课堂笔记
- 普适计算-2014/03/28
- Qlikview常用VB脚本
- libmudbus库使用的一二事
- Kubernetes Pod Eviction 简介
- 解决:input框当type为number时maxlength失效
- python supper代码详解
- python练习-句子逆序1
- 【机器学习】详解 转置卷积 (Transpose Convolution)