Web 开发避免不了经常修改表结构,手工修改表结构不仅容易出错,而且涉及到多人协作开发时,这么土的做法很不经济。

Django 的第三方 app South 就是专门做数据库表结构自动迁移的。Jacob Kaplan-Moss 曾做过一次调查,South 名列最受欢迎的第三方 app。事实上,它现在已经俨然成为 Django 事实上的数据库表迁移标准,很多第三方
app 都会带 South migrations 脚本。

South 最常用的功能要用起来也非常轻松。

安装配置

安装:

pip install South

修改 Django 项目的 settings 文件,在 INSTALLED_APPS 里追加 'south',

创建初始版本信息

第 1 步,生成表结构的初始版本,执行下面的命令后,会自动创建 your_app/migrations 目录并生成0001_initial.py 脚本:

./manage.py schemamigration your_app --initial

第 2 步,如果数据库中已经存在 your_app 的表结构,则需要通过 --fake 命令告诉
South:

./manage.py migrate your_app --fake

若不存在,用下面命令在数据库中创建表结构:

./manage.py migrate your_app

增加 Model 字段

为 your_app/models.py 增加字段后,执行下面的命令 South 会自动比对 0001_initial.py 并生成0002_auto__xxxx.py

./manage.py schemamigration your_app --auto

下面的命令便是立即修改数据库,使新的表结构版本生效:

./manage.py migrate your_app

其它说明

日常使用基本上就是这些命令,South 能做的当然还不只这些,还可以用它来做表格字段的重命名、生成迁移依赖关系图、单元测试集成等等,官方文档写的非常仔细:http://south.readthedocs.org/

另外,原来部署只需要执行 ./manage.py syncdb,集成 South 后需要多做一步 ./manage.py
migrate
,自动应用所有 app 的表结构迁移脚本。

另一篇博客

我们在用 Django 开发系统的时候常会遇到一个问题, 那就是资料库的栏位在开发的过程中有可能会更动,接著我们执行 syncdb 后会发现,原先存在的 model 在修改栏位后并不会更新到资料库。手动修改资料库栏位太过麻烦,但在资料库中有资料的时候我们又不想整个砍掉重练。这时候 South 就派上用场了。

South 可以自动帮我们搞定资料库 migrate 这件麻烦的工作,且可以让资料库做到版本控制。接下来的内容会简单介绍一下 South 的使用方法。









首先我们需要安装 south 这个模组。

pip install South

设定

把 south 加到 settings.py 的 INSTALLED_APPS 中

建立 south 的歷史纪录

 python manage.py syncdb

在 app 中使用 south

 python manage.py convert_to_south <app_name>

完成后会发现在专案目录下多出一个migrations资料夹,裡面会有个0001_initial.py档案,表示已经成功转换成south了。





使用

当修改完 schema 需要做 migrate 时,执行

 python manage.py schemamigration <app_name> <migration_name> --auto

这个指令会自动检查栏位的更动,并询问一些问题,完成后在 migrations 目录下会出现<version#>_<migration_name>.py

修改到资料库

 python manage.py migrate 





回复之前版本

在每次执行完 schemamigration 后,migrate 目录下的版本号 <version#> 会从 0001, 0002 一直增加上去 。 当需要回复到先前的版本时,只要执行

 python manage.py migrate <app_name> <version#>

完成后,资料库就会回到先前的版本了

但切到栏位少的版本再切回来...资料表中消失的资料当然是不会再回来的XD

South - 在 Django 中 Migrate Database的更多相关文章

  1. Django中如何使用django-celery完成异步任务1(转)

    原文链接: http://www.weiguda.com/blog/73/ 本篇博文主要介绍在开发环境中的celery使用,请勿用于部署服务器. 许多Django应用需要执行异步任务, 以便不耽误ht ...

  2. Django中的ORM

    Django中ORM的使用. 一.安装python连接mysql的模块:MySQL-python sudo pip install MySQL-python 安装完成后在python-shell中测试 ...

  3. 在Django中使用ORM创建图书管理系统

    一.ORM(对象关系映射) 很多语言的web框架中都有这个概念 1. 为什么要有ORM? 1. 写程序离不开数据,要使用数据就需要连接数据库,但是不同的数据库在sql语句上(mysql,oracle等 ...

  4. django中sqlite迁移mysql

    sqlite数据迁移 1 数据备份 django中打开terminalpython manage.py dumpdata authorization > authorization_data.j ...

  5. Django中的ORM框架使用小技巧

      Django中的ORM框架使用小技巧 作者:尹正杰  版权声明:原创作品,谢绝转载!否则将追究法律责任. Django对各个数据提供了很好的支持,包括PostgreSQL,MySQL,SQLite ...

  6. Django中的信号基础知识

    Django中提供了“信号调度”,用于在框架执行操作时解耦.通俗来讲,就是一些动作发生的时候,信号允许特定的发送者去提醒一些接受者. 1.Django内置信号 1 2 3 4 5 6 7 8 9 10 ...

  7. django中数据库操作有关部分

    # >>>>>>>>>>>>>>>>>>>>>>>>&g ...

  8. Django中一个项目使用多个数据库

    在django项目中, 一个工程中存在多个APP应用很常见. 有时候希望不同的APP连接不同的数据库,这个时候需要建立多个数据库连接. 参考:http://blog.csdn.net/songfree ...

  9. django中模型详解-字段类型与约束条件

    这片博文来详细说明django模型的使用,涉及到django模型的创建,字段介绍,以及django模型的crud操作,以及一对一等操作. 在使用模型之前,我们首先设置数据库选项,django的默认数据 ...

随机推荐

  1. Codeforces Round #379 (Div. 2) 解题报告

    题目地址 本次CF是在今天早上深夜进行,上午有课就没有直接参加.今天早上上课坐到后排参加了virtual participation.这次CF前面的题目都非常的水,不到10分钟就轻松过了前两题,比较郁 ...

  2. 安装了VS2010 sp1 后再安装ASP.NET MVC 3.0的问题

    安装了VS2010 sp1 后再安装ASP.NET MVC 3.0的问题(Final Result: Installation failed with error code: (0x80070643) ...

  3. c#基础知识-2

    1.在控制台接受数据时可以这样输入: using System; using System.Collections.Generic; using System.Linq; using System.T ...

  4. Apache代理Tomcat实现session共享构建网上商城系统

    一.环境介绍 二.安装配置后端服务器 三.安装配置前端服务器 四.配置Tomcat服务器实现session共享 五.构建网上商城系统 一.环境介绍 系统版本:CentOS 6.4_x86_64 Mys ...

  5. C++ 构造与析构函数

    这两个概念并不对等,构造函数可以完全控制成员构造过程(通过初始化列表),析构函数准确说应该叫析构之前被调用的函数 一般不应该手动调用析构函数:栈区对象会自动析构,堆区也是在delete的时候析构 有一 ...

  6. Modbus工业协议在Android中的应用

    现在工业信息画发展,很多工厂都需要做信息化展示,通常都是利用Android一体机来进行展示和交互. Modbus协议是全球第一个用于工业现场的总线协议,与外设交互可以采用串口通信,tcp等方式:通常在 ...

  7. Struts2之过滤器和拦截器的区别

    刚学习Struts2这个框架不久,心中依然有一个疑惑未解那就是过滤器和拦截器的区别,相信也有不少人跟我一样对于这个问题没有太多的深入了解 那么下面我们就一起来探讨探讨 过滤器,是在java web中, ...

  8. Unity3D 发布无边框exe

    关于:Unity3D 发布无边框exe,Unity3D Build exe无边框 Unity发布windows版本 总是带着边框,很想给它去掉,笔者在网上查了一番,常见的有3中. 1:通过unity3 ...

  9. Git 使用juju

    写在前面: 想不到好标题,就写好文章吧. 此篇主要是介绍在使用git过程中常见的一些命令以及遇到的问题,手册+答疑解惑! 在git未玩得通透熟练之际,此篇文章的标题序号无任何意义. 1.git 版本回 ...

  10. windows下在yii中使用mongodb

    1.编译或下载对应dll动态链接库拓展文件,下载地址:点我,不知道如何编译windows下的dll拓展->点我 2.找到web服务器软件,如apache,nginx等webserver处理浏览器 ...