Creating a Comprehensive Hackathon Database with Outerbase and Supabase πŸš€πŸ› οΈ

Creating a Comprehensive Hackathon Database with Outerbase and Supabase πŸš€πŸ› οΈ

Β·

4 min read

Introduction πŸ“

In this tutorial, we will walk you through the process of creating a robust hackathon database using Outerbase and Supabase. This database will allow you to efficiently manage hackathon details, challenges, teams, submissions, judges, and judging criteria. πŸ†πŸ”

Prerequisites πŸ§°βœ…

Before we begin, make sure you have the following:

  1. An account on Supabase: Sign up here. πŸŒπŸ”—

  2. A project set up on Supabase with credentials generated. πŸ—‚οΈπŸ”‘

Getting Started πŸπŸš€

1. Connecting to Supabase πŸŒπŸ”—

  1. Create a project on Supabase, select your region, and generate a password. πŸŒπŸ”

  2. Go to project settings and then database to find and copy all the necessary connection data. πŸ–±οΈπŸ“‹

2. Setting Up Outerbase πŸ§©πŸ”Œ

  1. Create an Outerbase account. πŸ†•πŸ”

  2. Connect your Outerbase account to Supabase using the previously copied credentials. πŸ”—πŸ”‘

3. Creating a New Base πŸ—„οΈπŸ†•

In Outerbase, create a new base to start building your hackathon database. πŸ› οΈπŸ—οΈ

Creating the Tables πŸ—ƒοΈπŸ“Š

Let's begin by creating the necessary tables for our hackathon database. πŸ—ƒοΈπŸ“Š

Hackathon Details Table πŸ“…πŸ“

  • Hackathon_ID (Unique identifier for each hackathon)

  • Hackathon_Name

  • Start_Date

  • End_Date

  • Location

  • Organizer_ID (Organizer's User_ID)

  • Description

Challenges Table

  • Challenge_ID (Unique identifier for each challenge)

  • Hackathon_ID (Foreign key referencing the Hackathon Details Table)

  • Challenge_Name

  • Description

  • Difficulty_Level

  • Prize

Teams Table

  • Team_ID (Unique identifier for each team)

  • Team_Name

  • Hackathon_ID (Foreign key referencing the Hackathon Details Table)

  • Team_Leader_ID (User_ID of the team leader)

  • Team_Size

Team Members Table

  • Team_ID (Foreign key referencing the Teams Table)

  • User_ID (Foreign key referencing the Users Table)

Submissions Table

  • Submission_ID (Unique identifier for each submission)

  • Team_ID (Foreign key referencing the Teams Table)

  • Challenge_ID (Foreign key referencing the Challenges Table)

  • Submission_Date

  • Status (e.g., Submitted, In Review, Accepted, Rejected)

  • Score

Judges Table

  • Judge_ID (Unique identifier for each judge)

  • First_Name

  • Last_Name

  • Email

Judging Criteria Table

  • Criterion_ID (Unique identifier for each criterion)

  • Challenge_ID (Foreign key referencing the Challenges Table)

  • Criterion_Name

  • Description

  • Max_Score

Scores Table

  • Submission_ID (Foreign key referencing the Submissions Table)

  • Criterion_ID (Foreign key referencing the Judging Criteria Table)

  • Score

Importing Data πŸ“€πŸ“₯

  1. Import the CSV file containing hackathon details, challenges, teams, etc., into Supabase. πŸ“€πŸ“₯

  2. Set the primary keys and save the data into the database. πŸ”‘πŸ’Ύ

Writing Queries πŸ“πŸ”

Now that we have set up our database, let's write some queries to retrieve and manage the data. πŸ“πŸ”

  1. Retrieve all hackathons:

     SELECT * FROM Hackathon_Details;
    
    • Description: This query retrieves all records from the "Hackathon Details" table, providing information about all hackathons.
  2. Retrieve all challenges for a specific hackathon:

     SELECT * FROM Challenges WHERE Hackathon_ID = <hackathon_id>;
    
    • Description: This query retrieves all challenges associated with a specific hackathon. Replace <hackathon_id> with the actual hackathon ID.
  3. Retrieve all teams for a specific hackathon:

     SELECT * FROM Teams WHERE Hackathon_ID = <hackathon_id>;
    
    • Description: This query retrieves all teams participating in a specific hackathon. Replace <hackathon_id> with the actual hackathon ID.
  4. Retrieve all team members for a specific team:

     SELECT * FROM Team_Members WHERE Team_ID = <team_id>;
    
    • Description: This query retrieves all members of a specific team. Replace <team_id> with the actual team ID.
  5. Retrieve all submissions for a specific team:

     SELECT * FROM Submissions WHERE Team_ID = <team_id>;
    
    • Description: This query retrieves all submissions made by a specific team. Replace <team_id> with the actual team ID.
  6. Retrieve all submissions for a specific challenge:

     SELECT * FROM Submissions WHERE Challenge_ID = <challenge_id>;
    
    • Description: This query retrieves all submissions made for a specific challenge. Replace <challenge_id> with the actual challenge ID.
  7. Retrieve the highest scoring submission for a specific challenge:

     SELECT TOP 1 * FROM Submissions WHERE Challenge_ID = <challenge_id> ORDER BY Score DESC;
    
    • Description: This query retrieves the highest scoring submission for a specific challenge. Replace <challenge_id> with the actual challenge ID.
  8. Retrieve the judges for a specific hackathon:

     SELECT * FROM Judges WHERE Judge_ID IN (SELECT Judge_ID FROM Judging_Criteria WHERE Challenge_ID IN (SELECT Challenge_ID FROM Challenges WHERE Hackathon_ID = <hackathon_id>));
    
    • Description: This query retrieves all judges associated with a specific hackathon. Replace <hackathon_id> with the actual hackathon ID.
  9. Retrieve judging criteria for a specific challenge:

     SELECT * FROM Judging_Criteria WHERE Challenge_ID = <challenge_id>;
    
    • Description: This query retrieves all judging criteria for a specific challenge. Replace <challenge_id> with the actual challenge ID.
  10. Calculate the average score for a specific team's submissions:

    SELECT AVG(Score) FROM Submissions WHERE Team_ID = <team_id>;
    
    • Description: This query calculates the average score for all submissions made by a specific team. Replace <team_id> with the actual team ID.

Queries πŸ“πŸ”

DataBase TablesπŸ“€

Conclusion πŸŽ‰πŸ₯³

Congratulations! You have successfully created a comprehensive hackathon database using Outerbase and Supabase. This database will allow you to efficiently manage hackathon events, challenges, teams, submissions, judges, and judging criteria. Feel free to customize and expand the database according to your specific needs. Happy hacking! πŸŽ‰πŸš€

Β