淺談Django學習migrate和makemigrations的差別
阿新 • • 發佈:2018-11-27
Python manger.py makemigrations
Python manger.py makemigrations user #對單個app
python manager.py migrate
python manger.py sqlmigrate theapp 0001
python manage.py shell
這篇文章主要介紹了淺談Django學習migrate和makemigrations的差別,具有一定借鑑價值,需要的朋友可以參考下
本文主要研究的是Django中migrate和makemigrations的差別,具體如下。
在你改動了 model.py的內容之後執行下面的命令:
Python manger.py makemigrations
相當於 在該app下建立 migrations目錄,並記錄下你所有的關於modes.py的改動,比如0001_initial.py, 但是這個改動還沒有作用到資料庫檔案
你可以手動開啟這個檔案,看看裡面是什麼
在此之後執行命令
python manager.py migrate
將該改動作用到資料庫檔案,比如產生table之類
當makemigrations之後產生了0001_initial.py 檔案,你可以檢視下該migrations會對應於什麼樣子的SQL命令
python manger.py sqlmigrate theapp 0001
大概是這個樣子的:
BEGIN; CREATE TABLE "polls_choice" ( "id" serial NOT NULL PRIMARY KEY, "choice_text" varchar(200) NOT NULL, "votes" integer NOT NULL ); CREATE TABLE "polls_question" ( "id" serial NOT NULL PRIMARY KEY, "question_text" varchar(200) NOT NULL, "pub_date" timestamp with time zone NOT NULL ); ALTER TABLE "polls_choice" ADD COLUMN "question_id" integer NOT NULL; ALTER TABLE "polls_choice" ALTER COLUMN "question_id" DROP DEFAULT; CREATE INDEX "polls_choice_7aa0f6ee" ON "polls_choice" ("question_id"); ALTER TABLE "polls_choice" ADD CONSTRAINT "polls_choice_question_id_246c99a640fbbd72_fk_polls_question_id" FOREIGN KEY ("question_id") REFERENCES "polls_question" ("id") DEFERRABLE INITIALLY DEFERRED; COMMIT;
總結
以上就是本文關於淺談Django學習migrate和makemigrations的差別的全部內容,希望對大家有所幫助。感興趣的朋友可以繼續參閱本站其他相關專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支援!
您可能感興趣的文章: