django1.8数据迁移

   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二步就完成了与数据库的同步。

相关文章
相关标签/搜索