DataEngPrep.tech
QuestionsPracticeAI CoachDashboardPacksBlog
ProLogin
Home/Questions/General/Other/Retrieve the most recent sale_timestamp for each product (Latest Transaction).

Retrieve the most recent sale_timestamp for each product (Latest Transaction).

General/Otherhard0.6 min read

**SQL (full row)**: `SELECT * FROM (SELECT *, ROW_NUMBER() OVER (PARTITION BY product_id ORDER BY sale_timestamp DESC) AS rn FROM sales) t WHERE rn = 1` — Returns the full record. **SQL (timestamp only)**: `SELECT product_id, MAX(sale_timestamp) FROM sales GROUP BY product_id` —...

🤖 Analyze Your Answer
Frequency
Low
Asked at 2 companies
Category
243
questions in General/Other
Difficulty Split
151E|43M|49H
in this category
Total Bank
1,863
across 7 categories
Asked at these companies
PresidioSwiggy
Interview Pro Tip

Red Flag: Using `DISTINCT ON` (Postgres) or `LAST_VALUE` without specifying frame—different engines have different semantics. Pro-Move: 'We use ROW_NUMBER because we need the full transaction record. We partition by product_id and cluster the table by product_id to minimize shuffle; we've seen 3x improvement over a naive GROUP BY + join.'

Key Concepts Tested
bigquerypartitionsnowflakesparksqlwindow

Why This Question Matters

This hard-level General/Other question appears frequently in data engineering interviews at companies like Presidio, Swiggy. While less common, it tests deeper understanding that distinguishes strong candidates. Mastering the underlying concepts (bigquery, partition, snowflake) will help you answer variations of this question confidently.

How to Approach This

This is a senior-level question that tests architectural thinking. Lead with the high-level design, then drill into specifics. Discuss trade-offs explicitly - there is rarely one correct answer. Show awareness of scale, fault tolerance, and operational complexity.

Expert Answer
126 words

SQL (full row): SELECT FROM (SELECT , ROW_NUMBER() OVER (PARTITION BY product_id ORDER BY sale_timestamp DESC) AS rn FROM sales) t WHERE rn = 1 — Returns the full record. SQL (timestamp only): SELECT product_id, MAX(sale_timestamp) FROM sales GROUP BY product_id — Use when you only need the timestamp. PySpark: df.withColumn('rn', F.row_number().over(Window.partitionBy('product_id').orderBy(F.desc('sale_timestamp')))).filter(F.col('rn') == 1).drop('rn') — Full row. For aggregation: df.groupBy('product_id').agg(F.max('sale_timestamp').alias('latest_sale')). Scalability trade-off: ROW_NUMBER requires a sort within each partition—O(n log n) per partition. On large datasets, ensure product_id is well-distributed to avoid skew. If one product has 90% of rows, that partition dominates. Consider salting or bucketing. Cost: In BigQuery/Snowflake, MAX with GROUP BY is often more efficient than window functions for large scans; use ROW_NUMBER when you need other columns from the winning row.

dataengprep.techdataengprep.techdataengprep.techdataengprep.tech
dataengprep.techdataengprep.techdataengprep.techdataengprep.tech
dataengprep.techdataengprep.techdataengprep.techdataengprep.tech
dataengprep.techdataengprep.techdataengprep.techdataengprep.tech
dataengprep.techdataengprep.techdataengprep.techdataengprep.tech
dataengprep.techdataengprep.techdataengprep.techdataengprep.tech

Want feedback on your answer?

Paste your answer to this question and our AI Coach scores it, finds gaps, and shows you the FAANG-level version.

Try Answer Analyzer →
Want all answers as a PDF for offline study?
1,863 questions across 7 categories — Interview Packs →
Related Study Guide
🎯

Presidio Data Engineer Interview Questions & Answers (2026)

Practice the 52 most asked data engineering questions at Presidio. Covers SQL, Spark/Big Data, General/Other and more.

10 min read →

Related General/Other Questions

hardHave you worked on Data Warehousing projects?FreemediumHow would you read data from a web API? What steps would you follow after reading the data?FreehardWhat is the difference between OLTP and OLAP?FreemediumWhat is the difference between SQL and NoSQL databases?FreeeasyACID Properties

Companies that ask this General/Other question

Presidio interview questions →Swiggy interview questions →

Want to know if YOUR answer is good enough?

Paste your answer and get instant AI feedback with a FAANG-level improved version.

Analyze My Answer — Free

According to DataEngPrep.tech, this is one of the most frequently asked General/Other interview questions, reported at 2 companies. DataEngPrep.tech maintains a curated database of 1,863+ real data engineering interview questions across 7 categories, verified by industry professionals.

← Back to all questionsMore General/Other questions →