Skip to main navigation Skip to search Skip to main content

Reservoir Sampling over Joins

  • Binyang Dai
  • , Xiao Hu
  • , Ke Yi

Research output: Contribution to journalJournal Articlepeer-review

Abstract

Sampling over joins is a fundamental task in large-scale data analytics. Instead of computing the full join results, which could be massive, a uniform sample of the join results would suffice for many purposes, such as answering analytical queries or training machine learning models. In this paper, we study the problem of how to maintain a random sample over joins while the tuples are streaming in. Without the join, this problem can be solved by some simple and classical reservoir sampling algorithms. However, the join operator makes the problem significantly harder, as the join size can be polynomially larger than the input. We present a new algorithm for this problem that achieves a near-linear complexity. The key technical components are a generalized reservoir sampling algorithm that supports a predicate, and a dynamic index for sampling over joins. We also conduct extensive experiments on both graph and relational data over various join queries, and the experimental results demonstrate significant performance improvement over the state of the art.

Original languageEnglish
Pages (from-to)70-78
Number of pages9
JournalSIGMOD Record
Volume54
Issue number1
Early online date29 Apr 2025
DOIs
Publication statusPublished - 29 May 2025

Bibliographical note

Publisher Copyright:
© 2025 Copyright is held by the owner/author(s)

Fingerprint

Dive into the research topics of 'Reservoir Sampling over Joins'. Together they form a unique fingerprint.

Cite this