Data Engineers
9.23K subscribers
314 photos
76 files
297 links
Free Data Engineering Ebooks & Courses
Download Telegram
Data Engineering Roadmap
โค4
Most Asked SQL Interview Questions at MAANG Companies๐Ÿ”ฅ๐Ÿ”ฅ

Preparing for an SQL Interview at MAANG Companies? Here are some crucial SQL Questions you should be ready to tackle:

1. How do you retrieve all columns from a table?

SELECT * FROM table_name;

2. What SQL statement is used to filter records?

SELECT * FROM table_name
WHERE condition;

The WHERE clause is used to filter records based on a specified condition.

3. How can you join multiple tables? Describe different types of JOINs.

SELECT columns
FROM table1
JOIN table2 ON table1.column = table2.column
JOIN table3 ON table2.column = table3.column;

Types of JOINs:

1. INNER JOIN: Returns records with matching values in both tables

SELECT * FROM table1
INNER JOIN table2 ON table1.column = table2.column;

2. LEFT JOIN: Returns all records from the left table & matched records from the right table. Unmatched records will have NULL values.

SELECT * FROM table1
LEFT JOIN table2 ON table1.column = table2.column;

3. RIGHT JOIN: Returns all records from the right table & matched records from the left table. Unmatched records will have NULL values.

SELECT * FROM table1
RIGHT JOIN table2 ON table1.column = table2.column;

4. FULL JOIN: Returns records when there is a match in either left or right table. Unmatched records will have NULL values.

SELECT * FROM table1
FULL JOIN table2 ON table1.column = table2.column;

4. What is the difference between WHERE & HAVING clauses?

WHERE: Filters records before any groupings are made.

SELECT * FROM table_name
WHERE condition;

HAVING: Filters records after groupings are made.

SELECT column, COUNT(*)
FROM table_name
GROUP BY column
HAVING COUNT(*) > value;

5. How do you calculate average, sum, minimum & maximum values in a column?

Average: SELECT AVG(column_name) FROM table_name;

Sum: SELECT SUM(column_name) FROM table_name;

Minimum: SELECT MIN(column_name) FROM table_name;

Maximum: SELECT MAX(column_name) FROM table_name;

Here you can find essential SQL Interview Resources๐Ÿ‘‡
https://t.me/mysqldata

Like this post if you need more ๐Ÿ‘โค๏ธ

Hope it helps :)
โค2
What is the difference between data scientist, data engineer, data analyst and business intelligence?

๐Ÿง‘๐Ÿ”ฌ Data Scientist
Focus: Using data to build models, make predictions, and solve complex problems.
Cleans and analyzes data
Builds machine learning models
Answers โ€œWhy is this happening?โ€ and โ€œWhat will happen next?โ€
Works with statistics, algorithms, and coding (Python, R)
Example: Predict which customers are likely to cancel next month

๐Ÿ› ๏ธ Data Engineer
Focus: Building and maintaining the systems that move and store data.
Designs and builds data pipelines (ETL/ELT)
Manages databases, data lakes, and warehouses
Ensures data is clean, reliable, and ready for others to use
Uses tools like SQL, Airflow, Spark, and cloud platforms (AWS, Azure, GCP)
Example: Create a system that collects app data every hour and stores it in a warehouse

๐Ÿ“Š Data Analyst
Focus: Exploring data and finding insights to answer business questions.
Pulls and visualizes data (dashboards, reports)
Answers โ€œWhat happened?โ€ or โ€œWhatโ€™s going on right now?โ€
Works with SQL, Excel, and tools like Tableau or Power BI
Less coding and modeling than a data scientist
Example: Analyze monthly sales and show trends by region

๐Ÿ“ˆ Business Intelligence (BI) Professional
Focus: Helping teams and leadership understand data through reports and dashboards.
Designs dashboards and KPIs (key performance indicators)
Translates data into stories for non-technical users
Often overlaps with data analyst role but more focused on reporting
Tools: Power BI, Looker, Tableau, Qlik
Example: Build a dashboard showing company performance by department

๐Ÿงฉ Summary Table
Data Scientist - What will happen? Tools: Python, R, ML tools, predictions & models
Data Engineer - How does the data move and get stored? Tools: SQL, Spark, cloud tools, infrastructure & pipelines
Data Analyst - What happened? Tools: SQL, Excel, BI tools, reports & exploration
BI Professional - How can we see business performance clearly? Tools: Power BI, Tableau, dashboards & insights for decision-makers

๐ŸŽฏ In short:
Data Engineers build the roads.
Data Scientists drive smart cars to predict traffic.
Data Analysts look at traffic data to see patterns.
BI Professionals show everyone the traffic report on a screen.
โค2
๐Ÿ“Š Data Science Summarized: The Core Pillars of Success! ๐Ÿš€

โœ… 1๏ธโƒฃ Statistics:
The backbone of data analysis and decision-making.
Used for hypothesis testing, distributions, and drawing actionable insights.

โœ… 2๏ธโƒฃ Mathematics:
Critical for building models and understanding algorithms.
Focus on:
Linear Algebra
Calculus
Probability & Statistics

โœ… 3๏ธโƒฃ Python:
The most widely used language in data science.
Essential libraries include:
Pandas
NumPy
Scikit-Learn
TensorFlow

โœ… 4๏ธโƒฃ Machine Learning:
Use algorithms to uncover patterns and make predictions.
Key types:
Regression
Classification
Clustering

โœ… 5๏ธโƒฃ Domain Knowledge:
Context matters.
Understand your industry to build relevant, useful, and accurate models.
โค1
Hereโ€™s a detailed breakdown of critical roles and their associated responsibilities:


๐Ÿ”˜ Data Engineer: Tailored for Data Enthusiasts

1. Data Ingestion: Acquire proficiency in data handling techniques.
2. Data Validation: Master the art of data quality assurance.
3. Data Cleansing: Learn advanced data cleaning methodologies.
4. Data Standardisation: Grasp the principles of data formatting.
5. Data Curation: Efficiently organise and manage datasets.

๐Ÿ”˜ Data Scientist: Suited for Analytical Minds

6. Feature Extraction: Hone your skills in identifying data patterns.
7. Feature Selection: Master techniques for efficient feature selection.
8. Model Exploration: Dive into the realm of model selection methodologies.

๐Ÿ”˜ Data Scientist & ML Engineer: Designed for Coding Enthusiasts

9. Coding Proficiency: Develop robust programming skills.
10. Model Training: Understand the intricacies of model training.
11. Model Validation: Explore various model validation techniques.
12. Model Evaluation: Master the art of evaluating model performance.
13. Model Refinement: Refine and improve candidate models.
14. Model Selection: Learn to choose the most suitable model for a given task.

๐Ÿ”˜ ML Engineer: Tailored for Deployment Enthusiasts

15. Model Packaging: Acquire knowledge of essential packaging techniques.
16. Model Registration: Master the process of model tracking and registration.
17. Model Containerisation: Understand the principles of containerisation.
18. Model Deployment: Explore strategies for effective model deployment.

These roles encompass diverse facets of Data and ML, catering to various interests and skill sets. Delve into these domains, identify your passions, and customise your learning journey accordingly.
โค3
ETL vs REVERSE ETL vs ELT
โค2
๐Š๐ฎ๐›๐ž๐ซ๐ง๐ž๐ญ๐ž๐ฌ ๐“๐ž๐œ๐ก ๐’๐ญ๐š๐œ๐ค

What it is: A powerful open-source platform designed to automate deploying, scaling, and operating application containers.

๐‚๐ฅ๐ฎ๐ฌ๐ญ๐ž๐ซ ๐Œ๐š๐ง๐š๐ ๐ž๐ฆ๐ž๐ง๐ญ:
- Organizes containers into groups for easier management.
- Automates tasks like scaling and load balancing.

๐‚๐จ๐ง๐ญ๐š๐ข๐ง๐ž๐ซ ๐‘๐ฎ๐ง๐ญ๐ข๐ฆ๐ž:
- Software responsible for launching and managing containers.
- Ensures containers run efficiently and securely.

๐’๐ž๐œ๐ฎ๐ซ๐ข๐ญ๐ฒ:
- Implements measures to protect against unauthorized access and malicious activities.
- Includes features like role-based access control and encryption.

๐Œ๐จ๐ง๐ข๐ญ๐จ๐ซ๐ข๐ง๐  & ๐Ž๐›๐ฌ๐ž๐ซ๐ฏ๐š๐›๐ข๐ฅ๐ข๐ญ๐ฒ:
- Tools to monitor system health, performance, and resource usage.
- Helps identify and troubleshoot issues quickly.

๐๐ž๐ญ๐ฐ๐จ๐ซ๐ค๐ข๐ง๐ :
- Manages network communication between containers and external systems.
- Ensures connectivity and security between different parts of the system.

๐ˆ๐ง๐Ÿ๐ซ๐š๐ฌ๐ญ๐ซ๐ฎ๐œ๐ญ๐ฎ๐ซ๐ž ๐Ž๐ฉ๐ž๐ซ๐š๐ญ๐ข๐จ๐ง๐ฌ:
- Handles tasks related to the underlying infrastructure, such as provisioning and scaling.
- Automates repetitive tasks to streamline operations and improve efficiency.

- ๐Š๐ž๐ฒ ๐œ๐จ๐ฆ๐ฉ๐จ๐ง๐ž๐ง๐ญ๐ฌ:
- Cluster Management: Handles grouping and managing multiple containers.
- Container Runtime: Software that runs containers and manages their lifecycle.
- Security: Implements measures to protect containers and the overall system.
- Monitoring & Observability: Tools to track and understand system behavior and performance.
- Networking: Manages communication between containers and external networks.
- Infrastructure Operations: Handles tasks like provisioning, scaling, and maintaining the underlying infrastructure.
โค2
Netflix Analytics Engineer Interview Question (SQL) ๐Ÿš€
---

### Scenario Overview
Netflix wants to analyze user engagement with their platform. Imagine you have a table called netflix_data with the following columns:
- user_id: Unique identifier for each user
- subscription_plan: Type of subscription (e.g., Basic, Standard, Premium)
- genre: Genre of the content the user watched (e.g., Drama, Comedy, Action)
- timestamp: Date and time when the user watched a show
- watch_duration: Length of time (in minutes) a user spent watching
- country: Userโ€™s country

The main objective is to figure out how to get insights into user behavior, such as which genres are most popular or how watch duration varies across subscription plans.

---

### Typical Interview Question

> โ€œUsing the netflix_data table, find the top 3 genres by average watch duration in each subscription plan, and return both the genre and the average watch duration.โ€

This question tests your ability to:
1. Filter or group data by subscription plan.
2. Calculate average watch duration within each group.
3. Sort results to find the โ€œtop 3โ€ within each group.
4. Handle tie situations or edge cases (e.g., if there are fewer than 3 genres).

---

### Step-by-Step Approach

1. Group and Aggregate
Use the GROUP BY clause to group by subscription_plan and genre. Then, use an aggregate function like AVG(watch_duration) to get the average watch time for each combination.

2. Rank Genres
You can utilize a window functionโ€”commonly ROW_NUMBER() or RANK()โ€”to assign a ranking to each genre within its subscription plan, based on the average watch duration. For example:

   AVG(watch_duration) OVER (PARTITION BY subscription_plan ORDER BY AVG(watch_duration) DESC)

(Note that in many SQL dialects, youโ€™ll need a subquery because you canโ€™t directly apply an aggregate in the ORDER BY of a window function.)

3. Select Top 3
After ranking rows in each partition (i.e., subscription plan), pick only the top 3 by watch duration. This could look like:

   SELECT subscription_plan,
genre,
avg_watch_duration
FROM (
SELECT subscription_plan,
genre,
AVG(watch_duration) AS avg_watch_duration,
ROW_NUMBER() OVER (
PARTITION BY subscription_plan
ORDER BY AVG(watch_duration) DESC
) AS rn
FROM netflix_data
GROUP BY subscription_plan, genre
) ranked
WHERE rn <= 3;


4. Validate Results
- Make sure each subscription plan returns up to 3 genres.
- Check for potential ties. Depending on the question, you might use RANK() or DENSE_RANK() to handle ties differently.
- Confirm the data type and units for watch_duration (minutes, seconds, etc.).

---

### Key Takeaways
- Window Functions: Essential for ranking or partitioning data.
- Aggregations & Grouping: A foundational concept for Analytics Engineers.
- Data Validation: Always confirm youโ€™re interpreting columns (like watch_duration) correctly.

By mastering these techniques, youโ€™ll be better prepared for SQL interview questions that delve into real-world scenariosโ€”especially at a data-driven company like Netflix.
โค6
Polymorphism in Python ๐Ÿ‘†
โค2