Skip to content

API development and Heroku deploy using FastAPI framework and data extraction from SQLite local hosted database.

Notifications You must be signed in to change notification settings

Jeanfabra/fastapi-sqlite-heroku

Repository files navigation

fastapi-sqlite-railway

API development and Railway deploy using FastAPI framework and data extraction from SQLite local hosted database.

General Steps

  1. Extract Transform and Load (ETL)
  2. Local Database creation in SQLite.
  3. Create connection with Python libraries (SQLAlchemy, Pydantic)
  4. Model & Schema development in SQLAlchemy
  5. main file structuring
  6. Railway deployment

About the dataset

The main dataset is a version of Kaggle Formula 1 World Championship dataset containing the following tables:

  • circuits
  • driver
  • races
  • constructor
  • laptimes
  • pitstops
  • qualifying
  • results

Formula One is the highest class of international racing for open-wheel single-seater formula racing cars sanctioned by the Fédération Internationale de l'Automobile (FIA). The dataset consists of all information on the Formula 1 from 1950 till the latest 2021 season.

1. Extract Transform and Load (ETL)

In this first process, data exploration was carried out, null data, repeated data and data that do not constitute the easily accessible data types were searched for. In general, the dataset was clean, the .jsons were exported as csv and meet the following load requirements: FIELDS TERMINATED BY ',' ENCLOSED BY '"' ESCAPED BY '' LINES TERMINATED BY '\r\n' IGNORE 1 ROWS;

2. Local Database creation in SQLite.

Once the datasets have been exported, the Database is created in SQLite for which DB Browser interface was used. There, primary keys and relationships among tables were made.

3, 4, 5 -> Create connection with Python libraries (SQLAlchemy, Pydantic) | Model & Schema development in SQLAlchemy | main file structuring

For these procedural steps FastAPI SQL Relational Database documentation was extremely helpful. This allowed to create a file structure:

  • database.py: Here we create the link between SQL Database and Python libraries/frameworks.
  • models.py: SQLAlchemy models are built so they can interact with the Database tables. Here, models is the way SQLAlchemy represents tables.
  • schemas.py: Pydantic models (schemas in this project) is to perform data validation, conversion, and documentation classes and instances.
  • crud.py: Create, Read, Update and Delete. In this file we create reusable functions that interact with Database. Although we only create functions for reading data, in the future it can be used for creating, updating and deleting data.
  • main.py: Code integration. It contains the FastAPI instantiated class object -> app.

6. Railway deployment

For deployment in Railway, the explicit requirements were established in requirements.txt. Procfile configuration in the Procfile file, and version of python to be used is specified in runtime.txt. Once the mandatory files are structured, the deployment is done in Railway dashboard.

+ Information to highlight.

Some API endpoints check for more in documentation

  • /docs documentation
  • /year-races year with most races
  • /best-driver driver with the highest number of first position
  • /most-run most drive circuit name
  • /best-score driver with the highest points

Railway Deploy Link

Contact

Greetings, Jean Paul Fabra Ruiz: jeanfabra11@gmail.com

LinkedIn: https://www.linkedin.com/in/jeanfabra/

About

API development and Heroku deploy using FastAPI framework and data extraction from SQLite local hosted database.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published