Coding — Unit 2#

SQL#

SQL (Structured Query Language) is a standard programming language specifically designed for managing and manipulating relational databases. It allows users to create, read, update, and delete data within a database, as well as to define and manage database structures. SQL is used to perform tasks such as querying data to retrieve specific information, inserting new data records, updating existing data, and deleting unwanted data. Additionally, SQL enables the creation of database schemas, the definition of relationships between different data tables, and the implementation of security measures to control access to the data. Its powerful and versatile nature makes SQL an essential tool for database management and analysis.

According to Stack Overflow’s 2023 Developer Survey [Overflow, 2023], SQL-based databases dominate the database management system (DBMS) market. It is estimated that approximately 90% or more of databases use SQL.

Database Resources#

For the following SQL section we will be using the following databases:

Below is the Relational Schemas for these databases

relational schemas

Exercise solutions can be found in the solutions section.

SELECT Statement#

The SQL SELECT statement is used to retrieve specific data from tables within a relational database. The data is return in the form of a table.

SELECT Tutorials#

Complete:

SELECT Exercises#

Using the Movies database:

  • Display the name of all the directors

  • Display the name of all the members

  • Display the details in the movie table

  • Display all the years of release with no duplications

  • Display the number of all movies on hire and when they are due back

WHERE clause#

The SQL WHERE clause is used to filter records in a database query to include only those that meet specified conditions.

WHERE Tutorials#

Complete

WHERE Exercises#

Using the Movies database

  • Display the name of all the US directors

  • Display the name of the all non-US directors

  • Display the name of all the members who owe money

  • Display all the movies that have ‘the’ in their title

  • Display all the movies that start with Z

Using the Repairs database

  • List the owners whose repair is ready to collect

  • List the owners whose iMac is still being repaired

Using the World database

  • Which countries have not achieved independence but still have a capital

  • Which countries are missing information?

  • List countries that are either constitutional monarchies or republics

Filters and Aggregators#

SQL filter clauses are used to restrict the number of rows returned by a query based on specified conditions, enabling more precise data retrieval and manipulation. While SQL aggregators are functions used to perform calculations on multiple rows of a table’s column and return a single value.

Filters and Aggregators Tutorials#

Complete:

Filters and Aggregators exercises#

Using the Movies database

  • How many directors are there from Australia?

  • How many directors have the name John?

  • What is the longest movie?

  • If I was to watch all the movies, back-to-back, how many minutes will I need (no pausing for toilet stops)

Using the Repairs database

  • What is the average repair rate?

  • How many repairs are waiting to be picked up?

Using the Shares database

  • How many companies are there in the high risk category?

  • Which company has the biggest difference between their highest and lowest price?

  • What is the cheapest, medium or low risk share on the New York Stock Exchange?

  • List all shares that are currently within 10% of their highest price?

ORDER BY#

The SQL ORDER BY keyword is used to sort the result set of a query by one or more columns, either in ascending (ASC) or descending (DESC) order.

ORDER BY Tutorials#

Complete:

ORDER BY Exercises#

Using the Movies database

  • List all the movies names in alphabetical order

  • What is the 5 oldest movie in stock?

  • Display the movies in chronological order, and then alphabetical order within each year.

Using the School Database

  • List the name of the grade 6 students in alphabetical order

  • What is the top three results in percentage

  • List all the boys’ birthdays in order, then all the girls’ birthdays in order, with their names

GROUP BY and HAVING#

The SQL GROUP BY statement is used to group rows that have the same values in specified columns into summary rows, often in conjunction with aggregate functions to perform calculations on each group. While the SQL HAVING statement is used to filter groups of rows created by the GROUP BY clause based on specified conditions, typically involving aggregate functions.

GROUP BY and HAVING Tutorials#

Complete:

GROUP BY and HAVING Exercises#

Using the Movies database

  • How many directors are there from each country?

  • How many movies does each member number have on hire?

  • How many movies are stocked from each year?

Using the School database

  • What is the average result for each subject(code)?

  • How many boys and girls in each grade?

Using the Shares database

  • How many companies are there in each risk category?

  • What is the cheapest, medium risk and cheapest low risk share on the New York Stock Exchange?

Using the Chinook database

  • How many customers are there from each country?

  • How many customers in each city?

  • How much were the sales for each country?

Subqueries#

SQL sub-queries are queries embedded within another SQL query to provide results that are used by the outer query, enabling more complex and flexible data retrieval and manipulation​. Subqueries are possible since every query returns a table. Effectively, you run one query which returns a table, then you run another query on the data in the returned table.

Subqueries Tutorials#

Complete:

Subqueries Exercises#

Using the Schools database

  • What are the percentage results for students in grade 7

  • What subject is taught by the teacher in room A2?

  • In which subjects did students score over 90%?

  • List the names of the students in grades 4 or 5 who scored over 50% for language.

  • List the names of students who do science.

Repairs database

  • Who owns devices being repaired by Ted Carrol?

  • What are the names of the technicians who are still not expert (N) at repairing Macs?

  • What rate will Byrne be charged for repairs?

  • List the owners whose devices have a high (H) priority for repair.

  • What level of qualification has the technician who is doing James’ repair job?

JOIN#

SQL join clauses are used to combine rows from two or more tables based on a related column between them, enabling the retrieval of data that spans multiple tables.

JOIN Tutorials#

Complete

JOIN Exercises#

Using the Schools database

  • What is the average percentage of the students for each teacher

  • List all the students taught by Mr Simms

Using the Chinook database

  • List all albums, including artist name

  • List the name of all the tacks in the metal genre

  • List all the details of all Def Leppard tracks.

Record Management#

SQL record management keywords, such as INSERT, UPDATE, and DELETE, are used to add new records, modify existing records, remove records in a database table respectively.

Record Management Tutorials#

Complete:

Record Management Exercises#

Using the Movies database

  • Add a new director record for Australian director Rachael Perkins

  • Add a new member record. Name: Melissa Small, Address: 38 Loggers Ln

  • Add movies on hire for Aliens being hired to Reis,E return date is in two weeks.

  • Update Fitzgerald,F’s address to 13 Elms St

  • Lennon,S has paid her fees, adjust the database appropriately

  • The store is doing a cull and getting rid of all movies before 1970, adjust the database appropriately.

Python and SQLite#

This section gives a brief overview of using SQLite in Python. W3schools give more details in this blog.

To work with SQLite in Python we will use the sqlite3 module. It is part of the Python standard Library, so it is already installed.

Setup#

There are three steps to setting up your Python code to use sqlite3:

1. Import the module#

This is your usual import command at the top of your Python file.

import sqlite3

2. Connect to the database#

You need to create a connection object. The connection object is used to make changes to the database file. Generate a connection object using the sqlite3.connect method and assign it to a variable.

import sqlite3

connection = sqlite3.connect("database_file.db")

3. Create a cursor#

Finally you need to create a cursor object. The cursor object is used to run SQL queries on the database via the connection object.

import sqlite3

connection = sqlite3.connect("database_file.db")
cursor = connection.cursor()

Now you are set to access your SQLite database with Python.

SQLite3 Queries#

There are two steps to running a query in using sqlite3 and Python.

1. Execute the SQL query statement#

The SQL query statement is provided as a string. Below is an example of how I format the code using a multiline string. It makes it easier to read, and, therefore, increases maintainability.

cursor.execute(
    """
    SELECT name, phone_num
    FROM customers
    """
)

2. Fetch the results#

Once the query has been executed, you need to fetch the results that are stored in the cursor. You have three fetching options:

  1. fetchall() - returns all the results

  2. fetchone() - returns the next result

  3. fetchmany(size) - returns the size number of rows

cursor.execute(
    """
    SELECT name, phone_num
    FROM Customers
    """
)

reults = cursor.fetchall()

SQLite3 INSERT, CREATE, UPDATE, DELETE#

All SQL statements that involve making changes to the database (INSERT, CREATE, UPDATE and DELETE) also have two steps, but they are slightly different.

Execute the SQL statement#

The first step in as the same. The cursor needs to be used to execute the SQL statement.

import sqlite3

cursor.execute(
    """
    INSERT INTO Customers (name, phone_num)
    VALUES ("John", "0434123456")
    """
)

Commit changes#

The changes to the database will not be permanent until they have been committed to the database file. You can commit numerous execute commands to the database in one go. To make the commitment we use the connection’s commit() method.

import sqlite3

cursor.execute(
    """
    INSERT INTO Customers (name, phone_num)
    VALUES ("John", "0434123456")
    """
)

connection.commit()

Using variables#

XKCD

To avoid SQL injection attacks, the correct way to insert variables values into your SQL statements is to use the parameter substitution method. This method inserts a placeholder in the SQL statement, and the values are then passes as a second argument to the execute() method. We will be using dictionaries to do this, although lists can also be used.

Parameterised Queries#

Below is an example of a parameterised query statement.

import sqlite3

cursor.execute(
    """
    SELECT name, phone_num
    FROM Customers
    WHERE name = :name
    """,
    {
        "name": "John"
    }
)

reults = cursor.fetchall()

Parameterised INSERT, CREATE, UPDATE, DELETE#

Below is an example of a parameterised insert statement

import sqlite3

cursor.execute(
    """
    INSERT INTO Customers (name, phone_num)
    VALUES (:name, :phone)
    """,
    {
        "name":"John",
        "phone":"0434123456"
    }
)

connection.commit()

Converting datastore to a database#

One of the advantages of using MVC Architecture is ease of refactoring. You can change any of the three modules, as long as calling the methods that interconnect the modules remain the same. For example, if you want to change the datastore module so it uses a database, you can change that one module and leave the main and UI module alone.

The videos below build on our hangman game from Unit 1 by changing the datastore to an SQLite database. The use of a database allows for other features like recording results and having multiple user, so the other two modules are adjusted to include these features. These video also provide an example of a stacked widget.

Repository for the tutorial resources

Python Type Hinting#

Python type hinting is a feature introduced in Python 3.5 that allows developers to specify the expected data types of variables, function parameters, and return values.

Type hint provides many benefits:

  • Improved Readability: Type hints make it easier for developers to understand what types of data are expected in different parts of the codebase.

  • Early Error Detection: Static type checking tools can detect mismatches between expected and actual data types, helping catch bugs early.

  • Better IDE Support: Type hints enable more accurate autocompletion and refactoring tools in IDEs.

  • Documentation: Serves as an additional form of documentation, making code easier to understand and maintain.

Never-the-less, there are also some limitations:

  • No Runtime Enforcement: Type hints do not enforce type checks at runtime, so they rely on external tools for validation. Complexity: For large codebases, maintaining type hints can become complex, especially with dynamic typing features in Python.

How Type Hinting Works#

Function Annotations#

Type hints are added using annotations in function definitions. For example, you can specify the types of parameters and return values using the colon : and the arrow ->.

def add(x: int, y: int) -> int:
    return x + y

In this example, x and y are expected to be integers, and the function add is expected to return an integer.

Variable Annotations#

Type hints can also be used for variables, although this doesn’t enforce the type but serves as documentation.

age: int = 25
name: str = "Alice"

Type Hints for Complex Data Types#

For more complex data types like lists, dictionaries, and tuples, the typing module provides various generic types.

from typing import List, Dict, Tuple

def process_data(data: List[int]) -> Dict[str, int]:
    return {"sum": sum(data), "count": len(data)}

coordinates: Tuple[float, float] = (39.9, -105.1)

Optional Types#

The Optional type is used to indicate that a variable can have a value of a specified type or be None.

from typing import Optional

def greet(name: Optional[str] = None) -> str:
    if name:
        return f"Hello, {name}!"
    return "Hello, stranger!"

Type Checking Tools#

Python type hints do not enforce type checks at runtime. However, tools like mypy, pytype, and IDEs such as PyCharm use these hints to perform static type checking, helping developers catch errors before runtime.