W3Cschool
恭喜您成為首批注冊用戶
獲得88經(jīng)驗值獎勵
當你運行遷移時,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ù)制到遷移文件中。
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網(wǎng)安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: