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` —...

🤖 Practice this in AI Interview
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.

The complete answer continues with detailed implementation patterns, architectural trade-offs, and production-grade considerations covering performance optimization and real-world examples.

This answer is partially locked

Unlock the full expert answer with code examples and trade-offs

Recommended

Start AI Mock Interview

Practice real interviews with AI feedback, track progress, and get interview-ready faster.

  • Unlimited AI mock interviews
  • Instant feedback & scoring
  • Full answers to 1,800+ questions
  • Resume analyzer & SQL playground
Create Free Account

Pro starts at $19/mo - cancel anytime

Just need answers for quick revision?

Download curated PDF interview packs

Interview Packs
R
P
A
S

Trusted by 10,000+ aspiring data engineers

AmazonGoogleDatabricksSnowflakeMeta
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

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 →