[Django1.6]south于django1.6使用
south在django1.6中的使用
django1.7中已经支持数据合并了,所以仅仅能在django1.4 1.5 1.6的版本号中使用south。 south的主要作用就是做数据的合并,当我们在django中定义了一个模型之后,使用syncdb同步到数据库中。而后假设 改动了模型的字段。或者字段属性,在使用syncdb就不能够了。 这时候假设要迁移数据就须要又一次建库,把原始数据 迁移到新库,south能够帮您自己主动的完毕这些操作。 之前一直没怎么用过,如今用的django版本号还是1.6,近期的开发属于 模型不是非常稳定的时间,于是就拿来使用下.
说明
- django1.6
- win7
- 数据库 mysql 5.6
安装
使用pip安装
pip install south
假设是升级sourh(1.0应该是最后一版)
pip install south --upgrade
django中配置
1
在你的django项目的settings文件里加入一个新的app (INSTALLED_APPS配置项)
INSTALLED_APPS = (
...
'south',
)
2
然后在项目下使用 python manage.py shell 打开django的shell
In [1]: import south
假设没有错误,说明安装配置好了。
3
使用之前先要在数据库中同步south的须要的表。
python manage.py syncdb
此时数据库中已经多了south_migrationhistory这个表。
使用
这是一个已经开发的项目,非常多表和表结构已经建立好也是用syncdb同步到数据库中。
app的名称是 adsr。 有个模型为
class AdDailyReport(models.Model):
ad = models.ForeignKey(Ad, on_delete=models.PROTECT)
ddate = models.DateField(auto_now=False, auto_now_add=False, verbose_name=u'统计日期')
pv = models.IntegerField(default=0, verbose_name=u'展现量')
pc = models.IntegerField(default=0, verbose_name=u'点击量')
cost = models.DecimalField(null=True,max_digits=10, decimal_places=2, verbose_name=u'花费')
addtime = models.DateTimeField(auto_now_add=True)
初始化合并
south有自己主动也有手动的合并方式。这里我们使用自己主动的方式
在没有不论什么模型变化的时候,对现有初始化:
E:\hawk>python manage.py convert_to_south adsr
This application is already managed by South.
然后才干够和新的app models一样,改动,合并模式,应用合并.
改动模型
模型最后加入了一个记录更新时间的字段
updatetime = models.DateTimeField(auto_now=True)
south 改动模式,应用
E:\hawk>python manage.py schemamigration adsr --auto
给了一些提示
E:\hawk>python manage.py schemamigration adsr --auto
?
The field 'AdDailyReport.updatetime' does not have a default specified, yet i
s NOT NULL.
? Since you are adding this field, you MUST specify a default
?
value to use for existing rows. Would you like to:
?
1. Quit now, and add a default to the field in models.py
?
2. Specify a one-off value to use for existing columns now
? Please select a choice:
google下stackoverflow上的回答, 然后例如以下的操作
?
Please select a choice: 2
? Please enter Python code for your one-off default value.
? The datetime module is available, so you can do e.g. datetime.date.today()
>>> datetime.datetime.now()
+ Added field updatetime on adsr.AdDailyReport
Created 0002_auto__add_field_addailyreport_updatetime.py. You can now apply this
migration with: ./manage.py migrate adsr
这样就把新的数据模型生成了。然后是应用。
E:\hawk>python manage.py migrate adsr
把表变更和数据合并应用。这样就把新的表结构生成,而且自己主动迁移数据。
ref
本文出自 “orangleliu笔记本”博客,转载请务必保留此出处http://blog.csdn.net/orangleliu/article/details/40394925
版权声明:本文orangleliu(http://blog.csdn.net/orangleliu/)原创文章。文章转载申报。
[Django1.6]south于django1.6使用的更多相关文章
- python之 centos6.7下 python 3.5.2、Django-1.9 安装
在linux6.5中已经自带了python 2 .python 2.6 ,并且yum程序使用的就是自带的python,所以系统自带的python不要随意卸载否则可能导致yum用不了. 测试环境:cen ...
- Cenos6.6 升级 python3.5.2 安装配置 django1.10
1 准备编译环境(环境如果不对的话,可能遇到各种问题,比如wget无法下载https链接的文件) yum groupinstall 'Development Tools' yum install zl ...
- python之 centos6.7下 python 3.5.2 源码、Django-1.9 安装
在linux6.5中已经自带了python 2 .python 2.6 ,并且yum程序使用的就是自带的python,所以系统自带的python不要随意卸载否则可能导致yum用不了. 测试环境:cen ...
- Sphinx编译docs文档
在使用Python.Django的过程中,经常看到docs目录,里面存放着一些txt文本文件,也就是自带的一些帮助文档,里面有make.bat,在dos目录下直接执行make,给出的帮助是可以转换成H ...
- Django基础—1
一. Django的安装1. 查看已安装的Django的版本 进入到终端以及Python的交互模式 python3/ ipython32. 交互模式中输入import django ...
- virtualenv虚拟环境安装不同版本的django
在开发Python应用程序的时候,系统安装的Python3只有一个版本:3.4.所有第三方的包都会被pip安装到Python3的site-packages目录下. 如果我们要同时开发多个应用程序,那这 ...
- nginx+django+uwsgi
最近来了兴致,想搞一下django开发,so, 搭建一下环境 1.安装django,可能通过pip install 或者源码安装(因为环境是python2.6.6的环境,所以这里采用django 1 ...
- nginx_uWSGI_django_virtualenv_supervisor发布web服务器
nginx_uWSGI_django_virtualenv_supervisor发布web服务器 nginx 导论 123456789101112131415161718192021222324252 ...
- Django2.0使用
创建项目: 通过命令行的方式:首先要进入到安装了django的虚拟环境中.然后执行命令: django-admin startproject [项目的名称] 这样就可以在当前目录下创建一个项目了. 通 ...
随机推荐
- 关于margin-right的应用问题
今天在群里面,有人抛出了一个关于css中margin-right没有效果的问题.CSS代码和HTML代码例如以下: .style1{ width:400px; height:440px; backgr ...
- VIM命令集
Command Action Notes vim file +54 open file and go to line 54 any : command can be run using + on co ...
- 特里-HDOJ-1671
Phone List Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ...
- MySQL命令行数据操作使用心得(总结版)
Char 0~255 Varchar 0~65535 text 0~65535(只能保存字符) Longtext 0~4294967295(只能保存字符) CMD登陆mysql mysql -u ro ...
- Kendo UI开发教程(16): Kendo MVVM 数据绑定(五) Events
本篇和Kendo UI开发教程(14): Kendo MVVM 数据绑定(三) Click类似,为事件绑定的一般形式.Events绑定支持将ViewModel的方法绑定到DOM元素的事件处理(如鼠标事 ...
- 【教你zencart仿站 文章1至6教训 高清1280x900视频下载】[支持手机端]
[教你zencart仿站 第1至6课 高清晰1280x900视频下载][支持移动端] 经过筹备, 我们的课件最终出来了- 我们 zencart联盟合伙人 项目推出的 在线yy同步演示zencart仿站 ...
- UVA - 12232 Exclusive-OR (并查集扩展偏离向量)
Description You are not given n non-negative integersX0,X1,..., Xn-1 less than220, but they do exist ...
- MySQL Full Join的实现
MySQL Full Join的实现 由于MySQL不支持FULL JOIN,以下是替代方法 left join + union(可去除反复数据)+ right join select * from ...
- Linux学习记录--命名管道通信
命名管道通信 什么是命名管道 一个主要的限制是,它是匿名管道的应用还没有名字,因此,只有它可以用于进程间通信的方式与亲缘关系.在命名管道(named pipe或FIFO)提出后,该限制得到了克服.FI ...
- 开源Math.NET基础数学类库使用(16)C#计算矩阵秩
原文:[原创]开源Math.NET基础数学类库使用(16)C#计算矩阵秩 本博客所有文章分类的总目录:http://www.cnblogs.com/asxinyu/p/4 ...