DEV Community

Cover image for MongoDB with Django
Anthony
Anthony

Posted on

MongoDB with Django

TLDR: Django doesn't support NoSQL databases like MongoDB, but this shows how it's possible.


Virtual Environments in Python

Before installing Django, its good to understand venv, a virtual environment for Python. venv is a self-contained directory that has the Python installation plus external packages. Think of it as any other virtual environment. They should NOT be committed to your repo (you can put it outside the directory or just add it to .gitignore)!

Create a venv with:

python3 -m venv name-of-virtual-env-directory
Enter fullscreen mode Exit fullscreen mode

This will create the name-of-virtual-env-directory as well as the Python installation and any packages your project needs.

A best practice for handling virtual environments is to store them all in the same place. So, you might want to store them in your home directory or wherever your Git repos are stored. i.e.:

python3 -m venv ~/.virtualenvs/project-virtual-env
Enter fullscreen mode Exit fullscreen mode

After that, you can activate the virtual environment with:

source ~./virtualenvs/project-virtual-env/bin/activate
Enter fullscreen mode Exit fullscreen mode

Anytime you install a package with pip, it will be installed in the active virtual environment you're in.

pip list
Enter fullscreen mode Exit fullscreen mode

Gives a list of all the installed packages within the venv.

After installing dependencies into the virtual environment, make sure to deactivate it when you're done. Use command:

deactivate
Enter fullscreen mode Exit fullscreen mode

pip freeze is similar to pip list, but it also give specific version numbers. Copy the contents of that list into a reqirements.txt file (which is committed into version control AKA Git). Then, when a user clones your project, they run the following, to install all of the project dependencies.

pip install -r requirements.txt
Enter fullscreen mode Exit fullscreen mode

Think of requirements.tx as package.json used in NPM.

| Another option: virtualenv is an even more popular option than venv. Look into using it here.

MongoDB

MongoDB is a NoSQL, non-relational, schema-less, document-based database. Document-based means that the data is stored in key-value pairs, think about JSON. Check out the table below for a comparison between SQL and NoSQL.

Topic SQL NoSQL
Type Table based databases Document based, like key-value pairs
Schema Uses a schema No need for a schema
Scaling Not preferred (vertical) Preferred for scaling (horizontal)
ACID Best for ACID properties Not ACID compliant

Image description

This shows how you need to create a schema with relational databases, and how it's not needed in MongoDB.

Django

MongoDB isn't officially supported by Django, a popular web framework with Python. PostresSQL, MySQL, Oracle, and SQLite are. But it is possible to do this per the MongoDB docs. This is because, usually, you'll want to use a relational database with Django.

Flask is another popular web framework in Python. It's a better choice to use with NoSql databases. You can also use django-nonrel, which is a community fork to add NoSQL support to Django. However, it is not supported and uses an old Django version.

There are 3 options to connect to MongoDB with Django. Pymongo, MongoEngine, and Djongo. But by using PyMongo, a driver, you can connect MongoDB and Django. Instructions for this are in the subsequent section.

After activating the virtual env (from above), installing Django can be done with:

python -m install Django
Enter fullscreen mode Exit fullscreen mode

View the Django version with:

python -m django --version
Enter fullscreen mode Exit fullscreen mode

cd into a directory and enter the command to create a project:

django-admin startproject name-of-project
Enter fullscreen mode Exit fullscreen mode

To start the server & application:

python manage.py runserver
Enter fullscreen mode Exit fullscreen mode

Earlier, we created a project named name-of-project. We can also create apps within the project. Projects can have multiple apps (think of apps as modules). Use this command:

python manage.py startapp name-of-app
Enter fullscreen mode Exit fullscreen mode
Directory Summary
name-of-project The root directory (can be named anything)
  » manage.py CLI utility
  » name-of-project Directory for the Python package (e.g. name-of-project.settings)
    » init.py Tells Python this directory is a package
    » settings.py Settings for Django
    » urls.py Table of contents and URL routing
    » asgi.py Entry-point for ASGI web servers
    » wsgi.py Entry-point for WSGI web servers

PyMongo

According to MongoDB docs, Pymongo is the preferred way to use MongoDB with Django. But as mentioned above, there are some other options using MongoEngine and Djongo.

Install PyMongo with:

python3 -m pip install pymongo
Enter fullscreen mode Exit fullscreen mode

For installation with MongoDB, it might be good to install some optional dependencies with:

pip install pymongo[snappy,gssapi,srv,tls]
Enter fullscreen mode Exit fullscreen mode

As well as this (for using mongodb+srv://):

pip install dnspython
Enter fullscreen mode Exit fullscreen mode

There's a couple of ways to connect to our database session. One of which involves creating a utils.py file in the PROJECT folder (where manage.py is).

from pymongo import MongoClient

def get_db_handle(db_name, host, port, username, password):

 client = MongoClient(host=host,
                      port=int(port),
                      username=username,
                      password=password
                     )
    db_handle = client['db_name']
 return db_handle, client
Enter fullscreen mode Exit fullscreen mode

Use env variables to hide the username and password from being exposed. That's out of scope of this tutorial, but if you have questions, just ask.

Then, in the app directory, find views.py. From here, the function get_db_handle() can be accessed.

Now, our MongoDB client is connected! If you'd like to check out how to set this up with MongoEngine or Djongo, just check out this tutorial.


For more information:


Thanks for reading!
Consider following me for more!

My Blog
Twitter
HashNode
Medium

Top comments (0)