Scanning and filtering over multi-dimensional tables are key operations in modern analytical database engines. To optimize the performance of these operations, databases often create clustered indexes over a single dimension or multi-dimensional indexes such as R-Trees, or use complex sort orders (e.g., Z-ordering). However, these schemes are often hard to tune and their performance is inconsistent across different datasets and queries. In this paper, we introduce Flood, a multi-dimensional in-memory read-optimized index that automatically adapts itself to a particular dataset and workload by jointly optimizing the index structure and data storage layout. Flood achieves up to three orders of magnitude faster performance for range scans with predicates than state-of-the-art multi-dimensional indexes or sort orders on real-world datasets and workloads. Our work serves as a building block towards an end-to-end learned database system.
CITATION STYLE
Nathan, V., Ding, J., Alizadeh, M., & Kraska, T. (2020). Learning Multi-Dimensional Indexes. In Proceedings of the ACM SIGMOD International Conference on Management of Data (pp. 985–1000). Association for Computing Machinery. https://doi.org/10.1145/3318464.3380579
Mendeley helps you to discover research relevant for your work.