文档章节

Migration: Python Django 1.7 的資料庫管理工具

 我的去哈哈
发布于 2015/04/26 11:24
字数 731
阅读 54
收藏 0

Migration 為 Django 1.7 版中新增的管理資料庫工具,在以前版本是藉由 south 來達成。
目的是加速資料庫schema更新的程序並提供資料庫的版本控制。

使用流程

用 Django 1.7 建立 app 時,app 底下會多出一個名為 migration 的次組件(subpackage)。
migration 中的檔案為均為自動生成,該檔案紀錄著各版本 model 的資料庫schema的差異以及版本間的相依性(dependency)。
創建初始時是空的僅有 _init_.py 檔,在app模型(model.py)完成後,可藉由指令自動生成 migration 檔案。

測試環境建構

可藉由下列指令來創建 project (mysite) 及 app (test_model)。

$django-admin.py startproject mysite
$python manage.py startapp test_model

再將 test_model 插入 setting.py 中的 INSTALLED_APPS

./mysite/mysite/setting.py
INSTALLED_APPS = (
    'test_model',)

一併將 app 中的 model.py 編輯成這裡用的測試檔案

./mysite/test_model/models.py
class testModel(models.Model):
    name = models.CharField(max_length=20)

migration 檔案生成

完成上述環境建構後就能用 makemigrations 測試啦

$python manage.py makemigrations test_model

上述指令會自動幫 test_model 中的 model.py 生成 migration 檔案。
若不填app名稱則對所有Django會自動對所有 INSTALLED_APPS 執行 makemigrations
Django 1.7 版中,每次對 model 作更動,要同步至 database 前都需要作 makemigrations

首次次呼叫指令時,migration 生成的檔名為 0001_initial.py,之後使用會依版本序號和更改的內容或時間來生成檔名。
例如:0002_testmodel_newfield.py 或 0003_auto_2014XXXX_XXXX.py

注意:
1.資料庫更改後,新增的 schema 都要填入 default 值,否則會出現下列狀況要求額外輸入預設值。

You are trying to add a non-nullable field 'comment' to test_model without a defa ult;
we can't do that (the database needs something to populate existing rows).
Please select a fix:
 1) Provide a one-off default now (will be set on all existing rows)     #在此手動輸入預設值
 2) Quit, and let me add a default in models.py    #離開,重新在*model.py*中增加預設值

2.各序號檔案彼此均有相依性,新版本會延續舊版本再加上更新項目,因此不能把舊的migration檔刪除。

資料庫更新

做完migration類別的檔案後,需再用migrate的指令來生成或更新資料庫。

$python manage.py migrate test_model 0001

test_model為app名稱,0001為要更新目標的版本編號。
藉由這個版本編號,migrate指令可將特定的app資料庫schema更新或返回先前版本。
若省略版本編號則自動更新到最新版,而省略app名稱則會對所有app執行migrate

資料庫的檔案及格式會依 setting.py 中 DATABASES 的資訊生成,預設是生成在project底下db.sqlite3 (此例中就是./mysite/db.sqlit3)
資料庫的內容可用資料庫瀏覽器 (如:sqlitebrowser) 檢視。

先前版本差異

  • 1.7版中,更新資料庫的動作需要 migration 類別,因此即使用 syncdb 同步資料前,也要先makemigration

https://docs.djangoproject.com/en/1.7/topics/migrations/

© 著作权归作者所有

共有 人打赏支持
粉丝 3
博文 57
码字总数 55253
作品 0
东城
Red Hat 翻新 JBoss 開發平台 跨入NoSQL市場

JBoss Data Grid 6,將提供Java及其他軟體使用NoSQL資料庫的能力。Red Hat將該軟體設定為能管理、使用大量資料又能快速反應的資料庫,具有容易擴展節點及容錯的特性。 Linux大廠Red Hat宣布,...

oschina
2012/06/22
1K
4
Python 的虛擬環境及多版本開發利器─Virtualenv 與 Pythonbrew

Virtualenv 和 Pythonbrew 都是可以創造虛擬(獨立)Python 環境的工具,只是虛擬(獨立)標的不同。 Virtualenv 可以隔離函數庫需求不同的專案,讓它們不會互相影響。在建立並啟動虛擬環境後...

jack_cheng
2013/10/11
0
0
python 的 开发利器之 Virtualenv 与 Pythonbrew

Virtualenv 和 Pythonbrew 都是可以創造虛擬(獨立)Python 環境的工具,只是虛擬(獨立)標的不同。 Virtualenv 可以隔離函數庫需求不同的專案,讓它們不會互相影響。在建立並啟動虛擬環境後...

首席安全砖家
2013/10/27
0
0
WEB框架之---Django初级篇

一、下载与安装(Windows版) 下载地址:https://www.djangoproject.com/download/ 或者通过命令:pip install django==1.11.2进行安装(Python3使用pip3)推荐使用此版本 安装完成后找到dja...

AltBoy
06/26
0
0
bug跟踪管理系统--Bug Tracker

Bug Tracker 是一個国人以 PHP 寫成的軟體缺陷追蹤系統,它可以協助您管理軟體開發流程。它使用資料庫幫您記住軟體缺失、待增的功能、待辦事項,可以讓您在管理軟體開發時更有效率。 大 多數...

匿名
2009/01/11
1K
0

没有更多内容

加载失败,请刷新页面

加载更多

为什么Java大神,都在看Spring Boot和Spring Cloud的书?

如果你是一名Java开发人员,并且最近正打算学习Spring Boot和Spring Cloud框架并寻找一些关于它们的最好的书籍,那么,你今天就来对地方了。 本文,我们将讨论一些学习Spring Boot和Spring ...

Java小铺
15分钟前
6
0
springboot logback日志配置

springboot 如果不使用外部tomcat的话,日志是需要自己配置的,不然的话就只有控制台的日志,但是日志又是我们在项目上了生产环境,出问题时,检查问题的唯一途径,所以我们要配置详细的日志...

曾大大胖
16分钟前
2
0
Linux服务器集体篡改时间的方法

Red Hat 虚拟化课程RH318,中小型公司使用的话,感觉可以匹敌OpenStack。手头上有一个VMware的映像,RHEV 3.5版的,只能把系统时间调整到2016年才能使用。Red Hat的RHEV已经更新到4.1版,不过...

大别阿郎
16分钟前
1
0
Tomcat启动异常:java.lang.ClassNotFoundException

警告: Name = mysqlDataSource Property maxActive is not used in DBCP2, use maxTotal instead. maxTotal default value is 8. You have set value of "100" for "maxActive" property, wh......

hengbao5
17分钟前
1
0
GO错误的一些处理(defer,recover,panic)

package main import("fmt""errors")func main() {num := 10fmt.Printf("num的类型%T, num的值%v, num的地址%v\n", num, num, &num)num2 := new(int) //返回一个指针//num...

汤汤圆圆
26分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部