Django4.0 遷移-歷史模型

2022-03-16 17:50 更新

當你運行遷移時,Django 正在使用存儲在遷移文件中的模型的歷史版本。如果你使用 RunPython 操作編寫 Python 代碼,或者你的數(shù)據(jù)庫路由上有 ?allow_migrate ?方法,則你 需要使用 這些模型的歷史版本而不是直接導(dǎo)入它們。

如果你直接導(dǎo)入模型而不是使用歷史模型,則遷移 最初可能會工作 但將來在嘗試重新運行舊遷移時會失敗(通常,當你設(shè)置新安裝并運行所有遷移時 以建立數(shù)據(jù)庫時)。
這意味著歷史模型的問題可能不會立即顯現(xiàn)。如果遇到這種故障,可以編輯遷移以使用歷史模型,而不是直接導(dǎo)入并提交這些更改。

因為不可能序列化任意的 Python 代碼,這些歷史模型不會有你定義的任何自定義方法。然而,它們將具有相同的字段、關(guān)系、管理器(僅限于那些具有 ?use_in_migrations = True?)和 ?Meta ?選項(也有版本控制,因此它們可能與當前的不同)。

這意味著在遷移中訪問對象時,將不會對對象調(diào)用自定義的 ?save()? 方法,也不會有任何自定義構(gòu)造函數(shù)或?qū)嵗椒ā_m當?shù)挠媱澮幌掳桑?br>

字段選項中對函數(shù)的引用,例如 ?upload_to ?和 ?limit_choices_to ?以及具有 ?use_in_migrations = True ?的模型管理器聲明,都會在遷移中序列化,因此只要有遷移引用它們,這些函數(shù)和類就需要保留。任何 自定義模型字段 也需要保留,因為這些都是直接由遷移導(dǎo)入的。
此外,模型的具體基類是以指針的形式存儲的,所以只要有一個包含對它們的引用的遷移,你就必須始終將基類保留在身邊。從好的方面來說,這些基類的方法和管理器都是正常繼承的,所以如果你一定需要訪問這些,你可以選擇將它們移到一個父類中。
要刪除舊的引用,你可以 壓縮遷移 或者,如果引用不多,把它們復(fù)制到遷移文件中。


以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號