django 从1.7版本开始起增长了一个新的数据迁移功能,在以前若是你数据models文件作了修改,若是是已经上线的项目就很是麻烦了,要反复测试不少次才能在正式库上修改,操做风险相对比较高,固然在1.6版本前也有第三方的数据迁移工具,例如south,在1.7版本前你们用这个作数据迁移的比较多,但如今从1.7版本开始就自带数据迁移功能了,由于django1.8是官方永久性支持版本,因此本篇咱们是在1.8环境下的操做,若是还用老版本的兄弟,建议尽快切换新版本,老版本都官方都不在支持了,数据迁移功能对老版本用户来讲,这个功能算是比较新的功能,有想用django1.8开发的朋友,就要了解数据迁移功能如何使用了,咱们今天就来看看如何使用该功能,首先创建咱们的models文件,假设咱们的models.py文件内容以下:python
class Post(models.Model):数据库
author = models.ForeignKey(User)django
title = models.CharField(max_length=150)app
text = models.TextField()运维
created_date = models.DateTimeField(blank=True, null=True)ide
这是一个典型的博客文章model,有了这个model,咱们如何让数据库也创建相应的表呢,以前的用syncdb,但如今咱们就要用migrate, 另外须要注意的是sysdb这个命令在1.9版本就没有了。工具
由于我以前已经同步一次数据库,因此为了了解这个功能的强大,我在models里增长一条语句,修改以下:post
class Post(models.Model):测试
author = models.ForeignKey(User)spa
title = models.CharField(max_length=150)
text = models.TextField()
created_date = models.DateTimeField(blank=True, null=True)
published_date = models.DateTimeField(blank=True, null=True)
首先咱们生成迁移脚本,运行:
python manage.py mkaemigrations
Migrations for 'blog':
0004_post_published_date.py:
- Add field published_date to post
运维完后并数据库并无发生变化,只是生成了要操做数据库的一些脚本文件,感兴趣的能够去migrations目录里查看。
接下来运行:
python manage.py migrate
输出:
Synchronizing apps without migrations:
Creating tables...
Running deferred SQL...
Installing custom SQL...
Running migrations:
Rendering model states... DONE
Applying blog.0004_post_published_date... OK
看到已经将published_date这个字段增长上了,你在数据库里会看到这个字段,若是你在运行makemigrations,会获得:
No changes detected
这代表你作的修改都已同步到数据库中,没有可改变的了,这个例子是展现的是增长字段,若是你是第一次运行,原理也是同样,就更简单了,因此有了migrate,之后model的的任何改变,例如增长,删除,修改,都先makemigrations, 而后migrate二步就完成了与数据库的同步。