This is work in progress …
Connect to MySql database (local)
Models as respresentations of database tables
Using templates to display data
Using forms to interact with data
Connect to MySql database (local)
This is the local setup. For the external implementation see Setup Django on WebhostPython.
Preparation
Make sure the local server (e.g. xampp) is installed and activated (e.g. in the xampp panel).
Open localhost/phpadmin to create a database. Make sure there is a user with full privileges.
Install python modules
2 | > pipenv install mysqlclient |
If you want to have direct access to the database tables, it is convenient to also instal ipython. This will allow to run scripts from the python console. See: delaing with existing data.
1 | > pipenv install ipython |
Database credentials
Install python module mysqlclient
Include database credentials in project/settings.py
3 | 'ENGINE' : 'django.db.backends.mysql' , |
4 | 'NAME' : 'database_name' , |
5 | 'USER' : 'database_username' , |
6 | 'PASSWORD' : 'database_password' , |
Migrate and create superuser
After getting the Django description of existing data, it is time to migrate the database and create a superuser.
1 | > python manage.py migrate |
2 | > python manage.py createsuperuser |
3 | > python manage.py check |
4 | > python manage.py runserver |
This will create the necessary tables that Django uses in the background. The command createsuperuser creates login-credentials for admin access. Login to confirm that it works.
top
Models as representations of databsae tables
Basically, a model is a Django-class that relates to a database. Models are derived from the Django-class django.db.models. The models of an app are stored in app/models.py. Generally, each model maps to a single database table.
Here is a simple model called Post. Post is a class that derives from django.db.models.Model. Post has three data-fields or variables. The first data-field is called title. It is a Charfield variable of length 200. The second is called author. It is the ForeingKey of the table and has various characteristics. The third data-field is called body and is a TextField variable.
02 | from django.db import models |
03 | class Post(models.Model): |
04 | title = models.CharField(max_length = 200 ) |
05 | author = models.ForeignKey( 'auth.User' , |
06 | on_delete = models.CASCADE, |
08 | body = models.TextField() |
Synchronize the new model with the database with makemigrations (notes that Post has been added) and migrate (includes Post in the database)
1 | > python manage.py makemigrations |
2 | > python manage.py migrate |
And register Post in app/admin.py
2 | from django.contrib import admin |
3 | from . models import Post |
5 | admin.site.register(Post) |
top
Using templates to display data
The data from Post can be displayed in in a template using the Django template language. Templates are .html files stored in the template-directory.
In the example the data from the Post-model are displayed in the tags of a {% block content%}, that {% extends ‘base.html’ %}. All posts are selected from the post.object_list using the open and close-tags for a {% for [condition] %} – {% endfor %} loop.
2 | {% extends 'base.html' %} |
5 | {% for post in object_list %} |
6 | < h2 >< a href = "" >{{ post.title }}</ a ></ h2 > |
An annoying feature might be that text that contains html-code might be autoescaped before dysplay. The consequence of this feature is that html-link show as bare text. To avoid this, autoescape can be turned of.
02 | {% extends 'base.html' %} |
05 | {% for post in object_list %} |
07 | < h2 >< a href = "" >{{ post.title }}</ a ></ h2 > |
08 | < p >{{ post.body }}</ p > |
Next, to access the template we need to adjust app/views.py to include Post as a ListView (BlogListView) on home.html
2 | from django.views.generic import ListView |
3 | from . models import Post |
5 | class BlogListView(ListView): |
7 | template_name = 'home.html' |
Finally, app/urls.py needs adjustment to link views.BlogListView to the home-url
2 | from django.urls import path |
6 | path(' ', views.BlogListView.as_view(), name = ' home'), |
top
Working with forms
top