Last Chance to Join the 6-Week Data Science Interview MasterClass (January Cohort) 🚀 | Just 4 slots remaining...

Top 100 SQL Interview Questions

Dan Lee's profile image
Dan LeeUpdated Nov 8, 20248 min read
Feature image - SQL interview prep for data analyst, data scientist and data engineer roles

Looking for REAL SQL interview questions asked in FAANGs and startups? Here's a comprehensive guide with REAL questions!

These questions are fair game across data analyst, data engineer, backend engineer, and database administrator interviews. Companies such as Google, Amazon, Meta, Stripe, Microsoft, and many more all ask SQL questions.

We will explore the question areas, uncover tips, and provide you with a detailed list of interview questions you can use to ace the interviews!

Let's get started👇

📚 SQL Interview Areas

Here are common areas assessed in SQL interviews across data roles.

Area 1 - Basic SQL Queries

Understanding basic SQL queries is fundamental. Expect questions that test your ability to retrieve, filter, and sort data using SELECT, WHERE, ORDER BY, and GROUP BY clauses. Also, SQL joins are essential for combining data from multiple tables. You should be comfortable with INNER JOIN, LEFT JOIN, RIGHT JOIN, and FULL OUTER JOIN.

Sample Questions

  1. Write a SQL query to find the second highest salary from the Employees table.
  2. How do you count the number of records in a table?
  3. Retrieve all records where the status is 'Active' from the Users table.
  4. Explain the difference between an INNER JOIN and a LEFT JOIN.
  5. Write a query to find all customers who have made more than one purchase.
  6. How do you retrieve data from three tables using joins?
💡

You don't need to know all the statements in SQL for interviews. In some cases, the interviewer will allow you to look up the statement. Just know the common ones, as seen in this guide.


Area 2 - Advanced SQL Concepts

Requiring multiple steps to solve, advanced SQL questions assess your understanding of subqueries, window functions, CTEs (Common Table Expressions), and set operations like UNION and INTERSECT.

Sample Questions

  1. Write a query to find the cumulative sum of sales per day.
  2. How do you delete duplicate records from a table?
  3. Calculate the 7-day moving average of daily sales.

💡 You can get practice questions with hands-on coding on DataInterview SQL Pad.


Area 3 - SQL Optimization and Performance

Performance is crucial in SQL. If you are shooting for senior DS or data engineering roles, you should know how to optimize queries, use indexes effectively, and understand execution plans.

Sample Questions

  1. What are the pros and cons of using indexes in a database?
  2. How does a full table scan impact query performance, and how can you avoid it?
  3. What techniques would you use to optimize a query that joins multiple large tables?
  4. Explain how the query execution plan helps in query optimization.
  5. What are common causes of deadlocks in SQL, and how can you prevent them?
  6. How does database partitioning improve query performance, and when should you use it?
  7. What is the difference between a covering index and a composite index, and when would you use each?

Area 4 - SQL in Data Warehousing and ETL

This is the part often assessed in data engineering or analytics engineering roles. Understanding how SQL is used in data warehousing and ETL processes is important for roles that deal with large datasets.

Sample Questions

  1. What is the purpose of a staging table in ETL, and how is it used?
  2. Explain the difference between OLTP and OLAP databases.
  3. How would you design a data pipeline to handle incremental data loads?
  4. What are surrogate keys, and why are they used in data warehousing?
  5. Describe the advantages of using a star schema over a snowflake schema.
  6. What are some common challenges in maintaining data quality in ETL processes, and how do you address them?
  7. How do you implement error handling in an ETL workflow to ensure data integrity?

SQL Interviews Across Data Roles

SQL questions are highly common across interviews in data roles from Data Analyst, Data Scientist and Data Engineer. Do expect SQL questions to show up in technical screens, and again in final rounds.

In some cases, a recruiter may ask basic SQL questions such as "explain JOINs" and "UNION vs UNION ALL" just to assess your basic knowledge before letting you advance to the technical screen.

  • Data Analyst (or BI Engineer) - Do expect SQL questions that involve table manipulation, but also in tandem with data visualization questions.
  • Data Scientist - Expect SQL questions with hands-on coding. Most often the questions pertain to a particular product of the company you are interviewing.
  • Data Engineer - Do expect intermediate to advanced questions and follow-ups regarding data modeling, optimization and databases.

👉 If you are looking for structured interview prep, join the Data Scientist Interview MasterClass - a live cohort led by FAANG instructors!


🎯 Common SQL Topics to Master

In general, you should have an in-depth understanding of the following topics:

  • Data Retrieval and Filtering
  • Aggregate Functions (COUNT, SUM, AVG, etc.)
  • Joins and Subqueries
  • Window Functions
  • Indexes and Query Optimization
  • Database Transactions and Isolation Levels
  • Stored Procedures and Functions
💡

Learn the ins-and-outs of these topics by practicing writing queries from scratch. This will be helpful in SQL coding interviews!


✍️ SQL Interview Technical Screen

Here's an example technical screen you may encounter if you interview for data analyst, data engineer or data scientist position at a company like Meta (Facebook) or Amazon. The technical screen round is usually 45 minutes. The first 20-30 minutes is primarily on SQL followed by a business or product case.

Tables Provided:

Listings Table

listing_idtitleseller_idcategorypricecreated_date
101Used Bicycle1Sports1502024-01-10
102Vintage Chair2Furniture2002024-03-15
103Laptop3Electronics8002024-02-20
104Smartphone4Electronics5002024-04-05
105Dining Table Set2Furniture4502024-01-25

Sellers Table

seller_idnamejoin_datelocationrating
1Alice2023-08-12New York4.8
2Bob2022-05-20San Francisco4.5
3Charlie2023-01-05Chicago4.9
4Diana2024-02-18Austin4.3
5Eve2022-11-11Seattle4.7

#1 - List the titles of the top 3 most expensive listings, along with the seller name and location, for sellers who joined in 2023 or later.

SELECT l.title, s.name, s.location
FROM Listings l
JOIN Sellers s ON l.seller_id = s.seller_id
WHERE s.join_date >= '2023-01-01'
ORDER BY l.price DESC
LIMIT 3;

#2 - Find sellers who have not listed any items in the 'Electronics' category. Display their name and total number of listings.

SELECT s.name, COUNT(l.listing_id) AS total_listings
FROM Sellers s
LEFT JOIN Listings l ON s.seller_id = l.seller_id AND l.category = 'Electronics'
WHERE l.listing_id IS NULL
GROUP BY s.name;

#3 - Find the seller(s) who joined the earliest but have listings priced higher than the average price in their respective categories. Display the seller name, title of the listing, and price.

SELECT s.name, l.title, l.price
FROM Sellers s
JOIN Listings l ON s.seller_id = l.seller_id
WHERE s.join_date = (SELECT MIN(join_date) FROM Sellers)
AND l.price > (SELECT AVG(price) 
               FROM Listings l2 
               WHERE l2.category = l.category);

📝 More SQL Interview Questions

These questions are fair game across data analyst, data engineer, backend engineer, and database administrator interviews at companies such as Google, Amazon, Meta, Stripe, and many more👇

Basic SQL Interview Questions

*For all data roles

  1. What is the difference between WHERE and HAVING clauses?
  2. Explain the use of GROUP BY and ORDER BY in SQL.
  3. How do you remove duplicate records from a table?
  4. What is a primary key and a foreign key?
  5. How do you use the LIKE operator?
  6. What are the different types of SQL JOINs?
  7. Explain the difference between DELETE, TRUNCATE, and DROP.
  8. What is the purpose of the DISTINCT keyword?
  9. How do you create and modify tables in SQL?
  10. What are constraints in SQL?
  11. Explain the difference between VARCHAR and CHAR data types.
  12. How do you use aggregate functions (COUNT, SUM, AVG, etc.)?
  13. What is the difference between UNION and UNION ALL?
  14. How do you use aliases in SQL?
  15. What is the purpose of the NULL value?
  16. How do you use wildcards in SQL?
  17. Explain the concept of SQL views.
  18. What is the difference between INNER JOIN and OUTER JOIN?
  19. How do you insert multiple rows into a table?
  20. What is the purpose of the BETWEEN operator?
  21. How do you use the IN operator?
  22. Explain the use of TOP and LIMIT clauses.
  23. What is the difference between DROP TABLE and DELETE FROM TABLE?
  24. How do you use string functions in SQL?
  25. What is the purpose of the COALESCE function?

Advanced SQL Interview Questions (20)

*For all data roles

  1. What are window functions and how do they work?
  2. Explain CTE (Common Table Expressions) and provide an example.
  3. How do you handle transactions in SQL?
  4. What are stored procedures, and why are they used?
  5. Explain the ACID properties in database systems.
  6. How do you use PIVOT and UNPIVOT operations?
  7. What are triggers and how do they work?
  8. Explain the concept of materialized views.
  9. How do you implement error handling in SQL?
  10. What are user-defined functions?
  11. How do you use MERGE statements?
  12. Explain recursive queries and their applications.
  13. What are table partitioning strategies?
  14. How do you implement row-level security?
  15. Explain the use of CROSS APPLY and OUTER APPLY.
  16. What are temporary tables and table variables?
  17. How do you handle dynamic SQL?
  18. Explain database isolation levels.
  19. What are indexed views and when should they be used?
  20. How do you implement hierarchical queries?

Performance and Optimization Questions

*For Data Engineers, sometimes in Senior DS roles.

  1. How do indexes improve query performance?
  2. What is a query execution plan and how do you analyze it?
  3. Explain the difference between clustered and non-clustered indexes.
  4. How do you avoid deadlocks in SQL?
  5. What strategies can you use to optimize a slow-running query?
  6. How do you identify and resolve blocking issues?
  7. What are statistics in SQL Server and why are they important?
  8. How do you optimize joins in large tables?
  9. Explain index fragmentation and how to address it.
  10. What are parameter sniffing issues and how do you resolve them?
  11. How do you optimize stored procedure performance?
  12. What is the impact of implicit conversions on performance?
  13. How do you handle missing indexes?
  14. Explain query plan caching and recompilation.
  15. What are wait statistics and how do you analyze them?

Database Design and Modeling Questions

*For Data Engineers, sometimes in Senior DS roles.

  1. Explain the concept of database normalization.
  2. What are the different types of relationships in databases?
  3. How do you design a database schema for a social media application?
  4. What is denormalization, and when would you use it?
  5. Explain the differences between OLTP and OLAP systems.
  6. How do you implement many-to-many relationships?
  7. What are the different normal forms (1NF through 5NF)?
  8. How do you handle soft deletes in database design?
  9. Explain the concept of data warehousing.
  10. What are dimensional modeling concepts?
  11. How do you implement versioning in database design?
  12. What are the best practices for database naming conventions?
  13. How do you handle temporal data in databases?
  14. Explain the star schema and snowflake schema.
  15. What are the considerations for designing a distributed database?

💡 How to Prepare for SQL Interviews

Tip 1 - Understand the SQL Interview Format

SQL interviews can vary widely—from answering theoretical questions to coding live on a shared document or platform. Interviews can be hands-on, with problems to solve on CoderPad, HackerRank, or even a whiteboard session. Prepare to showcase your understanding of SQL concepts, data manipulation, and writing optimized queries. Drill down practice questions with DataInterview SQL Pad.

Tip 2 - Practice Writing SQL Without Executing Code

In some interviews, you may not have access to an executable SQL environment. Practice writing SQL queries on paper or in plain text to develop confidence in your syntax and logic without relying on immediate feedback from an editor.

Tip 3 - Work with Real-World Datasets

Familiarize yourself with practical SQL applications by working with real-world datasets. Sites like Kaggle offer plenty of datasets that allow you to practice complex queries, data cleaning, and data analysis—mimicking the type of work you’d encounter in real projects or interviews.

Tip 4 - Join Communities

Finding study buddies is one of the best ways to prepare for interviews. Join community groups like DataInterview Premium Community where you can network with coaches and candidates who are currently preparing for interviews at top companies like Google, Meta, and Stripe. Spend some time each week reviewing sample questions together to enhance your understanding and stay motivated.

Tip 5- Practice Explaining Your Solutions Verbally

Interviewing isn’t just about writing code—it’s about explaining it. Practice explaining your thought process and query design as if you were in an interview. This will help you articulate the logic behind your approach and show your clear understanding of SQL concepts.


By mastering these areas and following these tips, you'll be well on your way to acing your SQL interviews!

Good luck :)

Dan Lee's profile image

Dan Lee

DataInterview Founder (Ex-Google)

Dan Lee is a former Data Scientist at Google with 8+ years of experience in data science, data engineering, and ML engineering. He has helped 100+ clients land top data, ML, AI jobs at reputable companies and startups such as Google, Meta, Instacart, Stripe and such.