django开发利器:South(数据层同步迁移)
2012-07-24 00:04
405 查看
在MVC层模型中,我们一般在Model定义我们的数据模型,而如果数据持久方案选择的是关系型数据库的话,怎么方便的在应用代码层的model模型和对应的数据表的schema同步,是个很重要的开发效率指标,在各个语言,各个开发框架中,都会为开发者考虑一点,像java中JDO中就有方便的migrate工具,或者rails中的migrate。可是在django中,只有manage.py syncdb命令,这个是很有局限性的,他只有在数据库中没有model对应的表时才会执行create table...的操作,对于字段的编辑,不会同步。这就要用到South这个东东。
解压后进入文件夹,执行:
python setup.py install
以上步骤理论上应该只执行一次,即初始化一次
以后每次models有改动时(任何结构变动:表的增加,删除,字段改变,索引改变....),执行如下命令即可,这个是循环的:
这样会把models中的变动同步到db结构中。
安装
下载
http://www.aeracode.org/releases/south/解压后进入文件夹,执行:
python setup.py install
配置
在django工程中找到settings.py文件在INSTALLED_APPS中添加“south”(INSTALLED_APPS可以动态添加模块)INSTALLED_APPS = ( ...... 'south' )
运行
因为south原理是通过每次将当前的最新models结构和上次历史版本比较,然后生成相应的改动文件。所以必需要有最初始化的首次版本(万事都要有个起点),所以要执行如下命令初始化:python manage.py schemamigration <你的工程名> --init
以上步骤理论上应该只执行一次,即初始化一次
以后每次models有改动时(任何结构变动:表的增加,删除,字段改变,索引改变....),执行如下命令即可,这个是循环的:
python manage.py schemamigration <你的工程名> --auto python manage.py migrate <你的工程名>
这样会把models中的变动同步到db结构中。
相关文章推荐
- Django 1.7 新数据迁移工具 (migrations) 的使用和如何从 South 升级转换
- [更新中]【South使用总结】django开发中使用South进行数据库迁移
- django 迁移数据 暂时禁用auto_now / auto_now_add
- android开发 如何通过web服务器访问MYSQL数据库并且使其数据同步到android SQLite数据库?
- Django数据库迁移组件(South)
- mysql 备份与迁移 数据同步方法
- Django开发利器——django-debug-toolbar 推荐
- 详解Java多线程开发中的数据同步
- MVC5中Model层开发数据注解 EF Code First Migrations数据库迁移 C# 常用对象的的修饰符 C# 静态构造函数 MSSQL2005数据库自动备份问题(到同一个局域网上的另一台电脑上) MVC 的HTTP请求
- 使用South对Django项目的数据库进行迁移的简明教程
- PgSQL · 内核开发 · 利用一致性快照迁移你的数据
- 在winform开发中,将集合类型(ArrayList)邦定到控件上,实现集合与控件中显示的数据同步
- 大数据开发利器:Hadoop(10) HBase进阶第3讲 批量插入Bulkload
- Kettle 合并记录和Merge Join组件实现数据增量迁移(数据同步比插入更新快
- SQL Mobile的RDA数据同步开发
- 菜鸟课堂:简介Java多线程开发中的数据同步
- 数据同步框架MS Sync Framework - IDE快速开发支持Local Database Cache
- 阿里云大数据利器Maxcompute学习之--数据同步任务常见日志报错总结
- Elasticsearch全文检索企业开发记录总结(四):数据同步
- 大数据开发利器:Hadoop(5)-HBase第二讲