Skip to content

New South Wales Department of Education (NSW DOE) are looking for humans who are passionate about improving education. We created this case study for our aspiring data team members to show off some data skills and use some of the data we work with.

Notifications You must be signed in to change notification settings

wisemuffin/nsw_doe_data_case_study

Repository files navigation

New South Wales Department of Education (NSW DOE) - Data Case Study 🦘

Open in GitHub Codespaces

New South Wales Department of Education (NSW DOE) are looking for humans who are passionate about improving education.

We created this case study for our aspiring data team members to show off some data skills and use some of the data we work with.

We want this case study to be as seamless as possible and take as little of your time as possible. That’s why we are using github code spaces which instantly sets up the same environment for you.

Find out more about the NSW Department of Education

The Case Study

Background

You will get data sets from the NSW Department of Education. We want you to ingest the data into a database, model the data and then analyse the data to provide us with some insights.

The data sets include (more info below):

  • Attendance
  • Multi-age composite classes (classes are made up of students drawn from different year levels)
  • School properties

Your Task

Multi-age classes may benefit students both socially and emotionally. NSW consistently performs above the national average in NAPLAN testing.

You have been tasked to bring some data into the data warehouse (duckdb) and provide some analysis into:

Does multi age composite classes have an impact on attendance rates?

What are we testing?

- Your ability to solve problems
- SQL modelling. Its only 3 datasets don’t go crazy. We are not fussed on what data modelling technique you choose (dimensional, one big table, ect)
- Data analysis. Give us your opinions and insights on what you find in the data
- Document your work (nothing fancy, a simple README.md file is more than enough)
- Work with version control (git)

Step 1 - Setup the case study environment

1.a Click the big green 'Use this template' button and 'Create a new repository'.

First make sure you have logged into github. You may need to sign up. If you havent logged in the template button wont appear.

Click use template

This will create a new repository exactly like this one, and navigate you there. Make sure to execute the next instructions in that repo.

1.b Click 'Code', then 'Codespaces, then 'Create codespace on main'.

Create codespace on main

This will create a new codespace, a sandboxed devcontainer with everything you need for the project.

1.c Make sure to wait til the codespace is finished setting up.

This will take around 2 mins to provision the environment

Codespaces setup screen at postCreateCommand

After the container is built and connected to, VSCode will run a few clean up commands and then a postCreateCommand, a set of commands run after the container is set up. This is where we install our dependencies, such as pandas, the duckdb adapter, and other necessities. That screen will look something like the above. When it's completed it will close and leave you in a fresh terminal prompt (like below). From there you're ready to do some data analysis!

DOE data download example

Step 2 - Investigating data already loaded into the database

public_school_nsw_master_dataset has already been loaded into the database which contains NSW public school fields. To run some SQL lets first get into the duckdb cli by entering the following into the command line:

Have a look at the data by running the following sql with sqltools duckdb driver:

example of running a query

Step 3 - Ingest data

3.a Explore the data

Ontop of the public_school_nsw_master_dataset preloaded into our warehouse lets bring in two more data sets. First preview the data for some initial data profiling, nice! Simply click on each link to preview the data:

2022 Attendance rates by Government Schools

2022 Multi age_composite classes) (hint this data needs some pivoting (columns for each year))

3.b Download the data

Feel free to choose to either download the data locally or connect to the APIs to get the data:

DOE data download example

Not familiar with working on Linux?

No worries, we mostly use windows too. You can simply run the wget command like so to download the data localy:

wget <url> -O ./data/<name of file>

example:

wget https://data.cese.nsw.gov.au/data/dataset/027493b2-33ad-3f5b-8ed9-37cdca2b8650/resource/2ac19870-44f6-443d-a0c3-4c867f04c305/download/master_dataset.csv -O ./data/public_school_nsw_master_dataset.csv

3.c Ingest the data

Several options:

Step 4 - Model the data

Perform any cleaning and modelling you think is necessary. We are not fussed on what data modelling technique you use (dimensional, one big table, ect).

Simply create your sql transformations as views or tables or just simple queries in the ./modelling/ folder.

Hints

  • the grain of the analysis is at the school level
  • one of the data sets will need to be unpivoted.)

Step 4a - Run you sql in duckdb via sqltools

Here is an example of creating a table with sql tools:

example of creating a table

Then you can query tables like we did above:

example of running a query

Now your turn. Model the data as you see fit before using it for the analysis step coming up next.

Step 5 - Analyse the data

Now the fun part! We want you to analyse the data and provide us with some insights. Feel free to use any tool you like. Couple of options that are aleady setup for you:

  • Jupyer notebooks (Python). We have already setup a jupyter notebook for you to use. See folder ./analysis/analysis-jupyter for more details. Do all your analysis and insights within the notebook. Select the python 3.11 kernel when prompted. Any additional libraries you add to the environment please add them to ./requirements.txt so we can also use them when viewing your work.
  • Evidence (Low code option in markdown and SQL) - an open source, code-based BI tool to write reports with markdown and SQL. See folder ./analysis/analysis-evidence for some examples. Simply do all your analysis and insight call outs in Evidence. For more detail on Evidence please see section on Tools included below.

Feel free to also bring the data from the data modellingg step into any tool you like. Some more examples:

  • Duckdb APIs exist for most languages (R, C++, Rust) and ODBC. See duckdb apis so feel free to connect to your favourite tool. We are just assessing your ability to communicate your insights.
  • Export data after modelling in duckdb into a csv and bring into excel and do your insights in powerpoint
  • Export data after modelling in duckdb into a csv and bring into powerbi.
  • hardest option Port forward duckdb from the codebase to your local machine and connect to it via your favourite tool.

Submitting your work

There are two possible senarios for submitting your work:

Submitting your work - If all your work is contained in this codespace

Make sure all you work is committed and pushed to your coppied repo.

Make sure the repo is public and send us the link to your repo.

Submitting your work - If you did your analysis outside of the codespace

Simply drag any external files into the ./analysis/ folder and commit them to your repo. If you have any issues then feel free to attach the files and send to us.

Make sure all you work is committed and pushed to your coppied repo.

Make sure the repo is public and send us the link to your repo.

Tools included

  • BI reporting built with Evidence - an open source, code-based BI tool to write reports with markdown and SQL.

Evidence

With Evidence you can:

  • Version control your BI layer
  • Deploy your reports to a static site

Running Evidence

To run Evidence, use:

task evidence

A popup will appear in your browser with a preview of your report. Or simply click ports and select port 3000:

Evidence access via port 3000

See the Evidence CLI docs for more details.

You can make changes to the markdown pages in the analysis/analysis-evidence/pages folder and see the reports update in the browser preview.

Learning More about Evidence

FAQ

Code space is running slow or disconnecting

If you have an unstable connection or you want to reduce latency between you and the IDE (integrated development environment) you can run VScode locally and it will remotley connect to the code space. This helps solve lots of latency issues. Github code space locally

Duckdb error unable to open database

If you get an error here saying Error: unable to open database "./database/nsw_doe_data_case_study.duckdb": IO Error: Could not set lock on file "./database/nsw_doe_data_case_study.duckdb": Resource temporarily unavailable then please close any other duckdb connections:

  • if you are connected via the cli please close the connection (ctrl + d)
  • please disconnect from SQL tools duckdb connection.

Disconnect from duckdb via sqltools

Duckdb when running in memory doesnt support similatnious connections. This limitation is currently being worked on. Click to see more info about this limitation

Contributing

We welcome issues and PRs requesting or adding new features.

About

New South Wales Department of Education (NSW DOE) are looking for humans who are passionate about improving education. We created this case study for our aspiring data team members to show off some data skills and use some of the data we work with.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published