[更新中]【South使用总结】django开发中使用South进行数据库迁移
Django开发中使用South进行数据库迁移的使用总结
South的详细资料可产看官方文档http://south.readthedocs.org/en/latest
South安装配置
pip install south
安装成功之后,修改django项目中的settings.py文件, 在INSTALLED_APPS中追加 ‘south’, 然后重新执行: ./manage.py syncdb 去创建South迁移跟踪表。
创建初始版本信息
一个new app(还未创建数据库表),在写好其应用里的models.py之后就可以生成数据库表结构的初始版本了。
第1步,执行 ./manage.py schemamigration your_app_name --initial 命令,生成表结构的初始版本,此命令执行后,会自动在你的app目录下创建一个migrations目录并生成0001_initial.py 脚本。
schemamigration只是在你的app中写入一个大的迁移, 真正要在数据库中迁移还要执行第2步。
第2步,执行 ./manage.py migrate your_app_name 命令,在数据库中创建表结构。
如果表结构已经存在, 则可以执行 ./manage.py migrate your_app_name --fake 命令, 告诉South对于已经存在的表结构不再创建。否则,会出现DatabaseError: table ”your_table“ alreadey exists的错误。我第一次使用就在操作失误导致一个表已经建立,出现这种问题。
修改Model字段
之后再对models.py文件作修改之后,如果自己去数据库中修改表的字段是很麻烦的。
第1步,执行 ./manage.py schemamigration your_app_name --auto 命令, south会自动对比你的app中migrations目录下的0001_initial.py并生成0002_auto_xxxx.py文件
第2步,执行 ./manage.py migrate your_app_name 让数据库修改表结构,使新版本表结构生效。
当在models.py的里添加新的属性时, 上述操作默认你添加的属性有一个default值, South会替你给数据库表中已存在的数据在新产生的字段上添加此默认值。如果在添加的属性没有默认值,也就是你在models.py中的类里添加新的属性时的参数null=False。 在执行第1步操作的时候, South会显示出两个选项:
./manage.py schemamigration your_app_name --auto
? The field 'your_model_class_name.new_attribute' does not have a default specified, yet is NOT NULL.
? Since you are adding or removing this field, you MUST specify a default
? value to user 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:
./manage.py schemamigration your_app_name --auto ? The field 'your_model_class_name.new_attribute' does not have a default specified, yet is NOT NULL. ? Since you are adding or removing this field, you MUST specify a default ? value to user 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:
如果你选择1, 那么指令不会做任何事并且退出, 之后你可以去修改你的models.py, 然后添加一个默认值。如果你选择2, 你将会看到一个Python的提示, 让你输入一个值, 用于你的这次迁移为那些已经存在的数据在新的字段上写入你输入的这个值。
? 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()
>>>
在>>>处输入你想要输入的值。对于你输入的值, 只会用于本次迁移时对已存在数据在新的字段上赋一个值。如果你不想你的model属性有默认值, 这样做是一个很好的选择。选择完选项之后,继续执行第2步完成迁移。
转化已存在app(数据库表已经创建) Converting to An App
有一个已经存在的应用, 而且数据库表已经创建, 要想进行数据库迁移, 需要以下三步:
第1步, 首先确保在settings.py中的INSTALLED_APP里添加了‘south’
第2步, 执行 ./manage.py syncdb 将South表加载(或者说是添加)到数据库中(如果没有, 无法执行迁移)
第3步, 执行 ./manage.py convert_to_south your_app_name -South会自动帮你执行并且假装你是第一次执行迁移。
[更新中]【South使用总结】django开发中使用South进行数据库迁移的更多相关文章
- django开发中利用 缓存文件 进行页面缓存
首先我们先来了解下浏览器的缓存 浏览器缓存机制 Cache-control策略 Cache-Control与Expires的作用一致,都是指明当前资源的有效期,控制浏览器是否直接从浏览器缓存取数据还是 ...
- django开发中关于外键设置
django开发中关于外键设置 我们建模型的时候会用到ForeignKey 而由于外键的约数会导致一些保存 所有我们ctrl+左键进入源码 源码 def __init__(self, to, on_d ...
- 怎样实现了捕获应用中的日志在android开发中
怎样实现了捕获应用中的日志在android开发中,大家可研究一下. Process mLogcatProc = null; BufferedReader reader = null; try { mL ...
- Python Django开发中XSS内容过滤问题的解决
from:http://stackoverflow.com/questions/699468/python-html-sanitizer-scrubber-filter 通过下面这个代码就可以把内容过 ...
- Django学习系列14:第一个数据库迁移
在Django中,ORM的任务是模型化数据库. 创建数据库其实是由另一个系统负责的叫做迁移. 迁移的任务是根据你对models.py文件的改动情况,添加或删除表和列. 可以把迁移想象成数据库使用的版本 ...
- 【Django】依赖auth.user的数据库迁移,以及admin用户非交互式创建
admin用户非交互式创建: echo "from django.contrib.auth.models import User; User.objects.create_superuser ...
- 【Django】Django开发中的日志输出
开发环境:Ubuntu16.04+Django 1.11.9+Python2.7 一:使用自定义函数输出日志到log文件: import time def print_log(log): file_o ...
- 那些在django开发中遇到的坑
1. 关于csrf错误 CSRF(Cross-site request forgery)跨站请求伪造,也被称为“one click attack”或者session riding,通常缩写为CSRF或 ...
- django 开发中数据库做过什么优化??
1.设计表时,尽量少使用外键,因为外键约束会影响插入和删除性能: 2.使用缓存,减少对数据库的访问: 3.在 orm 框架下设置表时,能用 varchar 确定字段长度时,就别用 text: 4.可以 ...
随机推荐
- maven 中pom.xml文件依赖包从本地加载如何配置?
比如我现在有一个需求是:项目中要加载ueditor的jar架构包,并且用maven构建的项目 那么在pom.xml文件中如配置: 说明:${project.basedir} 是maven 自带(内置) ...
- MapReduce-计数器
计数器 计数器是收集作业统计信息的有效手段之一,用于质量控制或应用级统计.计数器还可辅助诊断系统故障.根据计数器值来记录某一特定事件的发生比分析一堆日志文件容易得多.内置计数器Hadoop为每个作业维 ...
- eclipse添加删除插件-eclipse marketplace
源文地址:http://jingyan.baidu.com/article/cdddd41c5c883353cb00e19e.html 在有些版本的eclips上并没有eclipse marketpl ...
- QPushButton 响应回车 设置默认按钮
ui.pushButton->setFocus(); //设置默认焦点 ui.pushButton->setShortcut( QKeySequence::InsertParagraphS ...
- 在其他平台上使用 ActiveMQ
这一章讲了使用其他编程语言来访问 ActiveMQ,其他语言基本上都有相应的协议实现,所以说实现了协议,编程语言不是障碍! 还说了 ActiveMQ 提供了 RESTFul API 和 Ajax AP ...
- Memcache面试题
* memcached是怎么工作的? * memcached最大的优势是什么? * memcached和MySQL的query cache相比,有什么优缺点? * memcached和服务器的loca ...
- java:BufferedReader接受输入进来的2个数字,并将它们相加
java:BufferedReader接受输入进来的2个数字,并将它们相加 //接受输入进来的2个数字,并将它们相加 BufferedReader buf = null; buf = new Buff ...
- ES6-let命令
let命令 用于声明变量,但是声明的变量只能在let命令所在的代码块内有效, { let a = 10; var b = 1; } 其中,a在代码块的外部是调用不到的.对于for循环的计数器里面,就很 ...
- C#下利用正则表达式实现字符串搜索功能的方法(转)
关键字:正则表达式.元字符.字符串.匹配: 1.正则表达式简介:正则表达式提供了功能强大.灵活而又高效的方法来处:.NET框架正则表达式并入了其他正则表达式实现的: 2.字符串搜索:正则表达式语言由两 ...
- Android中如何禁止音量调节至静音
Android中音量按键在调低音量时,如果一直按住Down按钮不放,则系统将音量跳到最小后,又自动调节到静音状态.这个机制和iPhone是不同的,iPhone中无论你怎么按Volume-按钮,只能调到 ...