1. 程式人生 > >淺談Django學習migrate和makemigrations的差別

淺談Django學習migrate和makemigrations的差別

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的差別的全部內容,希望對大家有所幫助。感興趣的朋友可以繼續參閱本站其他相關專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支援!

您可能感興趣的文章:

出處:https://www.jb51.net/article/132259.htm