Skip to content

A simple starter full-stack application demonstrating REST DB interaction

Notifications You must be signed in to change notification settings

pwlee90/fastapi-rest-db

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

20 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

FastAPI Full-Stack REST Demo

This repo is a full-stack app using the FastAPI web framework, MySQL for a database, and REST to interact with a simple users table. You may install MySQL natively or use the included Docker file to create a database in a containter. The init-db.sql defines a simple schema for use with the example.

Screenshot

Prerequesites

You just need to have Python 3.7+ installed (3.10+ for the simplified typehinting).

Usage

  1. Create database credentials (specify your own USERNAME, PASSWORD, and ROOT_PASSWORD!)

    echo "MYSQL_HOST=localhost" > credentials.env
    echo "MYSQL_DATABASE=ece140" >> credentials.env
    echo "MYSQL_USER=USERNAME" >> credentials.env
    echo "MYSQL_PASSWORD=PASSWORD" >> credentials.env
    echo "MYSQL_ROOT_PASSWORD=ROOT_PASSWORD" >> credentials.env
  2. If you have Docker installed, run the following command to start up a MySQL server (ignore this step if you already have MySQL installed and modify the credentials.env file to match your database credentials!). Run the command in a separate terminal window as it will lock up the window for logging.

    docker compose up --build &

    Note: Just closing the terminal will not stop the database server. In order to stop it, you must issue the command docker-compose down when you are finished.

  3. Create a Python virtual environment

    python3 -m venv env
  4. Start the virtual environment

    source env/bin/activate
  5. Install dependencies

    pip install -U pip
    pip install -r requirements.txt
  6. Run the server

    cd server
    python main.py

    or

    cd server
    uvicorn main:app --reload
  7. If you prefer, there is a main-pydantic.py implementation as well. Instead of using the request object directly, this example uses the helpful Pydantic models to reduce cognitive load, so feel free to check that one out as well. Usage is exactly the same!

    cd server
    python main-pydantic.py

    or

    cd server
    uvicorn main-pydantic:app --reload

About

A simple starter full-stack application demonstrating REST DB interaction

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 61.3%
  • JavaScript 20.3%
  • HTML 11.5%
  • CSS 6.9%