In this article, we will create a basic model of an app. Say, we have a project geeksforgeeks in which we will create a new app in order to simplify and make independent model units.
To create an app run command through terminal :
python manage.py startapp geeks
and add geeks to INSTALLED_APPS list in
settings.py. Now directory structure of the app will be,
Now go to
models.py in geeks app, Here we will create our first model. To create a model you need to first import the Model from
Now models.py will look like,
According to Django documentation, A model is the single, definitive source of information about your data. It contains the essential fields and behaviours of the data you’re storing. Generally, each model maps to a single database table.
Django provides a number of predefined fields and methods to create a Model. To create a model you need to specify a model name first.
Enter the following code into
The similar syntax would always be used to create a model.
After making any change in any of app’s models file you need to run following command from the terminal
Python manage.py makemigrations
After this command run following command to finally implement database changes accordingly
Python manage.py migrate
After you run makemigrations and migrate a new table would have been created in database. You can check it from geeks -> makemigrations -> 0001_initial.py.
Let’s understand clearly what Makemigrations and Migrate do.
makemigrations basically generates the SQL commands for preinstalled apps (which can be viewed in installed apps in settings.py) and your newly created apps’ model which you add in installed apps. It does not execute those commands in your database file. So tables are not created after makemigrations.
After applying makemigrations you can see those SQL commands with sqlmigrate which shows all the SQL commands which have been generated by makemigrations.
migrate executes those SQL commands in the database file. So after executing migrate all the tables of your installed apps are created in your database file.
You can confirm this by installing sqlite browser and opening
db.sqlite3 you can see all the tables appears in the database file after executing migrate command.
- Django App Model - Python manage.py makemigrations command
- Django manage.py migrate command | Python
- How to Create a Basic Project using MVT in Django ?
- Render Model in Django Admin Interface
- Add the slug field inside Django Model
- Django model data types and fields list
- Django Models | Set - 1
- How to Create an App in Django ?
- Django Models | Set - 2
- Django Templates | Set - 1
- Django Templates | Set - 2
- BigIntegerField - Django Models
- Django Project MVT Structure
- DateField - Django Models
- How to use Django Field Choices ?
If you like GeeksforGeeks and would like to contribute, you can also write an article using contribute.geeksforgeeks.org or mail your article to email@example.com. See your article appearing on the GeeksforGeeks main page and help other Geeks.
Please Improve this article if you find anything incorrect by clicking on the "Improve Article" button below.