10 Trainline SQL Interview Questions (Updated 2024)

Updated on

March 3, 2024

At Trainline, SQL is used day-to-day for extracting and analyzing railway booking data, and for managing and manipulating databases for customer trend prediction. So, it shouldn't surprise you that Trainline frequently asks SQL coding questions during interviews for Data Science and Data Engineering positions.

To help you study for the Trainline SQL interview, we've collected 10 Trainline SQL interview questions – able to answer them all?

10 Trainline SQL Interview Questions

SQL Question 1: Analyze the Ticket Sales Over Time

Trainline, being a digital platform for selling train tickets, may be interested in understanding how their ticket sales have evolved overtime for each route.

Let's say we have a simple database table , which contains the details of each ticket sold. The table schema and some sample data are as follows:

Example Input:
sale_idroute_idsale_dateticket_price
2321100106/08/2022 00:00:0050.00
3452200106/10/2022 00:00:0045.00
9563100106/30/2022 00:00:0055.00
4222300107/01/2022 00:00:0080.00
7245200107/22/2022 00:00:0046.00
8562300107/25/2022 00:00:0080.00

The SQL interview question could be: Write a SQL query to calculate the total monthly revenue and average ticket price for each route.

This question requires knowledge of SQL window functions to sum, average over a group of records which fall within a specific date range (month), and partition by each route.

The expected output may look as follows:

Example Output:
mthroute_idtotal_revenueavg_ticket_price
61001105.0052.50
6200145.0045.00
7200146.0046.00
73001160.0080.00

Answer:


This query groups the data by month and route_id and then calculates the total and average ticket price for each group. By using the date_trunc function, we can easily group the data by month. The ORDER BY clause ensures that the result is sorted by month and then by total revenue in descending order.

Pro Tip: Window functions are a frequent SQL interview topic, so practice all the window function problems on DataLemur

DataLemur SQL Questions

SQL Question 2: Design a database for Trainline's Ticket Booking System

Imagine you are a data engineer at Trainline, a company that sells train tickets. Your task is to design a database for handling bookings. Essential entities to consider are stations, trains, and tickets.

Trainline's ticket booking system should support these functionalities:

  1. A list of all departure and arrival stations.
  2. The train schedules, that is, each trains' departure and arrival time at each station.
  3. The ability to book tickets where booking details such as passenger name, booking date, the departure station, arrival station, departure time, and arrival time are kept.

Example:

station_idstation_name
1London
2Manchester
3Glasgow
Example:
train_idtrain_name
1Galia Express
2Victoria Line
Example:
schedule_idtrain_iddeparture_station_idarrival_station_iddeparture_timearrival_time
111209:00:0011:30:00
222314:00:0016:00:00
Example:
ticket_idpassenger_namebooking_datedeparture_station_idarrival_station_iddeparture_timearrival_time
1John Doe2022-01-011209:00:0011:30:00

Answer to how many tickets were sold between 2 stations in a specific time range:


This query will return the count of all tickets sold for a specific route in a specific time range. You replace , , , and with your desired values. The operator in the clause will ensure you only consider tickets booked within the time range you want.

SQL Question 3: How do you identify records in one table that aren't in another?

To find records in one table that aren't in another, you can use a and check for values in the right-side table.

Here's an example using two tables, Trainline employees and Trainline managers:


This query returns all rows from Trainline employees where there is no matching row in managers based on the column.

You can also use the operator in PostgreSQL and Microsoft SQL Server to return the records that are in the first table but not in the second. Here is an example:


This will return all rows from employees that are not in managers. The operator works by returning the rows that are returned by the first query, but not by the second.

Note that isn't supported by all DBMS systems, like in MySQL and Oracle (but have no fear, since you can use the operator to achieve a similar result).

Trainline SQL Interview Questions

SQL Question 4: Filter Trainline Customer Records by Specific Conditions

As a data analyst for Trainline, your task is to filter the customer records based on the following conditions:

  • The customer has made at least one booking in the past 6 months.
  • The departure station of their most recent booking is 'London'.
  • The travel class of their most recent booking is 'First Class'.
  • The customer has not cancelled any booking in the last year.

You are provided with two tables, and .

The table is formatted as follows:

Example Input:
booking_idcustomer_idbooking_datedeparture_stationarrival_stationtravel_class
10012002022-01-20LondonManchesterFirst Class
10022012022-02-15BirminghamLondonStandard
10032002022-03-10LondonEdinburghFirst Class
10042022022-04-25LondonBristolStandard
10052032022-05-30ManchesterBirminghamFirst Class

The table is formatted as follows:

Example Input:
cancel_idbooking_idcancel_date
50110022022-02-16
50210052022-06-01
50310042022-04-27
50410042022-05-01

Answer:

Here is the SQL Postgres query to solve the above problem:


This query filters out the customers who satisfy all the given conditions, providing the customer_id of the user who made their most recent booking under these conditions.

First, it filters out the records with a booking date within the last 6 months, where the departure station is London and the travel class is First Class. It then excludes the bookings which are present in the cancellations table within the last year. The ORDER BY and LIMIT 1 clause ensure that we retrieve only the most recent booking that meets these conditions.

SQL Question 5: What's the purpose of the constraint?

The constraint is used to establish a relationship between two tables in a database. This ensures the referential integrity of the data in the database.

For example, if you have a table of Trainline customers and an orders table, the customer_id column in the orders table could be a that references the id column (which is the primary key) in the Trainline customers table.

SQL Question 6: Calculating Click-Through-Rates for Trainline

Trainline is a company that offers various routes and ticket bookings for trains and coaches. As a part of their digital marketing strategy, they often use ads that lead a user to their website or app. From there they hope user will not just view the different routes and tickets, but also add them to their cart.

Given two tables, and , your task is to calculate the click-through rate (CTR) from viewing a route to adding it to the cart by date. The table logs every click on an ad that redirects to a route view while the table logs every addition of a ticket to the cart.

Example Input:
click_iduser_idclick_dateroute_id
150842906/08/202230169
178271306/10/202240590
176944606/12/202230169
229514506/15/202250702
279036606/18/202240590
Example Input:
addition_iduser_idadd_dateroute_id
271542906/08/202230169
346371306/10/202240590
367344606/12/202230169
495314506/15/202250702
570243406/18/202240590

Answer:


To calculate the CTR, this query joins and tables on , and fields. Then it counts the number of tickets added to the cart and divides it by number of ad clicks for each date and route. This value is then multiplied by 100 to get a percentage value. The results are grouped by date and route_id. The query orders by to provide a chronological view of CTR.

To practice another question about calculating rates, try this TikTok SQL question within DataLemur's online SQL code editor: TikTok SQL question

SQL Question 7: Can you explain what an index is and the various types of indexes?

In a database, an index is a data structure that improves the speed of data retrieval operations on a database table at the cost of additional writes and the use of more storage space to maintain the index data structure.

There are several types of indexes that can be used in a database:

  1. Primary index: a unique identifier for each row in a table and is used to access the row directly.
  2. Unique index: used to enforce the uniqueness of the indexed columns in a table. It does not allow duplicate values to be inserted into the indexed columns.
  3. Composite index: is created on multiple columns of a table. It can be used to speed up the search process on the combination of columns.
  4. Clustered index: determines the physical order of the data in a table. There can be only one clustered index per table.
  5. Non-clustered index: does NOT determine the physical order of the data in a table. A table can have multiple non-clustered indexes.

SQL Question 8: Find The Most Popular Routes

Suppose we want to find out the most popular routes by the number of tickets sold per month. Each ticket sale is logged to a sales table, which includes the train route id, ticket id, and the sale date.

Example Input:
sale_idroute_idticket_idsale_date
23875011030106/08/2022
12937021345606/10/2022
50935011287206/18/2022
11327021423607/26/2022
49175011564107/05/2022
Example Output:
monthrouteticket_count
65012
67021
75011
77021

Answer:


This SQL query will group all ticket sales by month and route_id, count the number of tickets for each group, and order the results by month and the number of tickets in descending order. This gives us the most popular routes (identified by 'route') for each month.

SQL Question 9: Finding Customer Data in Train records

Assume you are given a database of Trainline customers who have booked train tickets in the past. Your task is to find customers whose first name starts with 'M' and have booked their tickets on 'London-Plymouth' route. The query should return the customer's first name, last name, and the date they booked the ticket.

Example Input:
customer_idfirst_namelast_name
007MarkSmith
463JohnBrown
591MatthewJones
812MarioRossi
073MadelineArchibald
Example Input:
booking_idcustomer_idbooking_dateroute
52100706/08/2022London-Plymouth
61246306/10/2022London-Bristol
34959106/18/2022London-Plymouth
72481207/26/2022London-Edinburgh
96507307/05/2022London-Plymouth

Answer:


This SQL command joins the 'customers' and 'bookings' tables on the 'customer_id'. It then filters the result where the customer's first name starts with 'M' and the route is 'London-Plymouth'.

SQL Question 10: What does the keyword do?

The keyword removes duplicates from a query.

Suppose you had a table of Trainline customers, and wanted to figure out which cities the customers lived in, but didn't want duplicate results.

table:

namecity
AkashSF
BrittanyNYC
CarlosNYC
DiegoSeattle
EvaSF
FayeSeattle

You could write a query like this to filter out the repeated cities:


Your result would be:

city
SF
NYC
Seattle

How To Prepare for the Trainline SQL Interview

The key to acing a Trainline SQL interview is to practice, practice, and then practice some more! Beyond just solving the earlier Trainline SQL interview questions, you should also solve the 200+ FAANG SQL Questions on DataLemur which come from companies like Facebook, Google and unicorn tech startups. DataLemur Questions

Each problem on DataLemur has multiple hints, step-by-step solutions and most importantly, there's an interactive coding environment so you can easily right in the browser your SQL query and have it checked.

To prep for the Trainline SQL interview it is also helpful to practice SQL questions from other tech companies like:

But if your SQL foundations are weak, don't worry about going right into solving questions – go learn SQL with this SQL tutorial for Data Scientists & Analysts.

Interactive SQL tutorial

This tutorial covers topics including CASE/WHEN/ELSE statements and handling missing data (NULLs) – both of these pop up often during Trainline SQL assessments.

Trainline Data Science Interview Tips

What Do Trainline Data Science Interviews Cover?

In addition to SQL interview questions, the other types of questions tested in the Trainline Data Science Interview are:

Trainline Data Scientist

How To Prepare for Trainline Data Science Interviews?

The best way to prepare for Trainline Data Science interviews is by reading Ace the Data Science Interview. The book's got:

  • 201 Interview Questions from Facebook, Google, & Amazon
  • A Refresher covering SQL, Product-Sense & ML
  • Amazing Reviews (900+ reviews, 4.5-star rating)

Ace the DS Interview

© 2025 DataLemur, Inc

Career Resources

Free 9-Day Data Interview Crash CourseFree SQL Tutorial for Data AnalyticsSQL Interview Cheat Sheet PDFUltimate SQL Interview GuideAce the Data Job Hunt Video CourseAce the Data Science InterviewBest Books for Data AnalystsSQL Squid Game